diff options
Diffstat (limited to 'kspread/kspread_view.cpp')
-rw-r--r-- | kspread/kspread_view.cpp | 7541 |
1 files changed, 7541 insertions, 0 deletions
diff --git a/kspread/kspread_view.cpp b/kspread/kspread_view.cpp new file mode 100644 index 00000000..519e4425 --- /dev/null +++ b/kspread/kspread_view.cpp @@ -0,0 +1,7541 @@ +/* This file is part of the KDE project + Copyright (C) 2005-2006 Raphael Langerhorst <raphael.langerhorst@kdemail.net> + (C) 2006 Stefan Nikolaus <stefan.nikolaus@kdemail.net> + (C) 2002-2005 Ariya Hidayat <ariya@kde.org> + (C) 1999-2003 Laurent Montel <montel@kde.org> + (C) 2002-2003 Norbert Andres <nandres@web.de> + (C) 2002-2003 Philipp Mueller <philipp.mueller@gmx.de> + (C) 2002-2003 John Dailey <dailey@vt.edu> + (C) 1999-2003 David Faure <faure@kde.org> + (C) 1999-2001 Simon Hausmann <hausmann@kde.org> + (C) 1998-2000 Torben Weis <weis@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 <kprinter.h> // has to be first + +// standard C/C++ includes +#include <assert.h> +#include <stdlib.h> +#include <time.h> + +// TQt includes +#include <tqbuffer.h> +#include <tqclipboard.h> +#include <tqcursor.h> +#include <tqlayout.h> +#include <tqpaintdevicemetrics.h> +#include <tqregexp.h> +#include <tqtimer.h> +#include <tqtoolbutton.h> +#include <tqsqldatabase.h> +#include <tqlistview.h> +#include <tqsizepolicy.h> + +// KDE includes +#include <dcopclient.h> +#include <dcopref.h> +#include <tdeapplication.h> +#include <tdeconfig.h> +#include <kdebug.h> +#include <kfind.h> +#include <kfinddialog.h> +#include <tdefontdialog.h> +#include <kinputdialog.h> +#include <tdemessagebox.h> +#include <knotifyclient.h> +#include <kpassdlg.h> +#include <kprocio.h> +#include <kreplace.h> +#include <kreplacedialog.h> +#include <tdespell.h> +#include <tdespelldlg.h> +#include <kstatusbar.h> +#include <kstdaction.h> +#include <kstandarddirs.h> +#include <tdetempfile.h> +#include <tdeparts/partmanager.h> +#include <tdelistview.h> +#include <kpushbutton.h> + +// KOffice includes +#include <tkcoloractions.h> +#include <kdatatool.h> +#include <KoCharSelectDia.h> +#include <KoCommandHistory.h> +#include <KoMainWindow.h> +#include <KoOasisLoadingContext.h> +#include <KoOasisStore.h> +#include <KoOasisStyles.h> +#include <KoPartSelectAction.h> +#include <KoStoreDrag.h> +#include <KoTabBar.h> +#include <kspread_toolbox.h> +#include <KoTemplateCreateDia.h> +#include <KoZoomAction.h> + +// KSpread includes +#include "commands.h" +#include "damages.h" +#include "digest.h" +#include "inspector.h" +#include "ksploadinginfo.h" +#include "kspread_canvas.h" +#include "kspread_editors.h" +#include "kspread_events.h" +#include "kspread_global.h" +#include "kspread_handler.h" +#include "kspread_locale.h" +#include "kspread_map.h" +#include "selection.h" +#include "kspread_sheetprint.h" +#include "kspread_style.h" +#include "kspread_style_manager.h" +#include "kspread_undo.h" +#include "testrunner.h" +#include "valuecalc.h" +#include "valueconverter.h" + +// dialogs +#include "dialogs/kspread_dlg_angle.h" +#include "dialogs/kspread_dlg_area.h" +#include "dialogs/kspread_dlg_comment.h" +#include "dialogs/kspread_dlg_conditional.h" +#include "dialogs/kspread_dlg_cons.h" +#include "dialogs/kspread_dlg_csv.h" +#include "dialogs/kspread_dlg_database.h" +#include "dialogs/kspread_dlg_format.h" +#include "dialogs/kspread_dlg_formula.h" +#include "dialogs/kspread_dlg_goalseek.h" +#include "dialogs/kspread_dlg_goto.h" +#include "dialogs/kspread_dlg_insert.h" +#include "dialogs/kspread_dlg_layout.h" +#include "dialogs/kspread_dlg_list.h" +//#include "dialogs/kspread_dlg_multipleop.h" +#include "dialogs/kspread_dlg_paperlayout.h" +#include "dialogs/kspread_dlg_pasteinsert.h" +#include "dialogs/kspread_dlg_preference.h" +#include "dialogs/kspread_dlg_reference.h" +#include "dialogs/kspread_dlg_resize2.h" +#include "dialogs/kspread_dlg_series.h" +#include "dialogs/kspread_dlg_show.h" +#include "dialogs/kspread_dlg_showColRow.h" +#include "dialogs/kspread_dlg_sort.h" +#include "dialogs/kspread_dlg_special.h" +#include "dialogs/kspread_dlg_styles.h" +#include "dialogs/kspread_dlg_subtotal.h" +#include "dialogs/kspread_dlg_validity.h" +#include "dialogs/link.h" +#include "dialogs/sheet_properties.h" +#include "dialogs/kspread_dlg_find.h" +#include "dialogs/SheetSelectWidget.h" +#include "kspread_propertyEditor.h" +#include "kspread_generalProperty.h" + +// KSpread DCOP +#include "KSpreadViewIface.h" + +#include "kspread_view.h" + +namespace KSpread +{ +class ViewActions; + +class View::Private +{ +public: + View* view; + Doc* doc; + DCOPObject* dcop; + + // the active sheet, may be 0 + // this is the sheet which has the input focus + Sheet* activeSheet; + + // GUI elements + TQWidget *frame; + TQFrame *toolWidget; + Canvas *canvas; + VBorder *vBorderWidget; + HBorder *hBorderWidget; + TQScrollBar *horzScrollBar; + TQScrollBar *vertScrollBar; + KoTabBar *tabBar; + KStatusBarLabel* calcLabel; + + // formulabar, consists of: + TQHBoxLayout* formulaBarLayout; + ComboboxLocationEditWidget *posWidget; + TQButton* formulaButton; + TQButton *okButton; + TQButton *cancelButton; + KSpread::EditWidget *editWidget; + TQGridLayout* viewLayout; + TQHBoxLayout* tabScrollBarLayout; + + // all UI actions + ViewActions* actions; + + // If updateEditWidget is called it changes some TDEToggleActions. + // That causes them to emit a signal. If this lock is true, then these + // signals are ignored. + bool toolbarLock; + + // if true, kspread is still loading the document + // don't try to refresh the view + bool loading; + + // selection/marker + Selection* selection; + Selection* choice; + TQMap<Sheet*, TQPoint> savedAnchors; + TQMap<Sheet*, TQPoint> savedMarkers; + TQMap<Sheet*, KoPoint> savedOffsets; + + // Find and Replace context. We remember the options and + // the strings used previously. + long findOptions; + TQStringList findStrings; + TQStringList replaceStrings; + FindOption::searchTypeValue typeValue; + FindOption::searchDirectionValue directionValue; + // Current "find" operation + KFind* find; + KReplace* replace; + int findLeftColumn; + int findRightColumn; + TQPoint findPos; + TQPoint findEnd; + + InsertHandler* insertHandler; + + // Insert special character dialog + KoCharSelectDia* specialCharDlg; + + // Holds a guarded pointer to the transformation toolbox. + TQGuardedPtr<KoTransformToolBox> transformToolBox; + + // the last popup menu (may be 0). + // Since only one popup menu can be opened at once, its pointer is stored here. + // Delete the old one before you store a pointer to anotheron here. + TQPopupMenu *popupMenu; + int popupMenuFirstToolId; + + TQPopupMenu *popupRow; + TQPopupMenu *popupColumn; + TQPopupMenu* popupChild; // for embedded children + TQPopupMenu* popupListChoose; // for list of choose + + // the child for which the popup menu has been opened. + Child* popupChildObject; + + // spell-check context + struct + { + KSpell * tdespell; + Sheet * firstSpellSheet; + Sheet * currentSpellSheet; + Cell * currentCell; + MacroUndoAction *macroCmdSpellCheck; + unsigned int spellCurrCellX; + unsigned int spellCurrCellY; + unsigned int spellStartCellX; + unsigned int spellStartCellY; + unsigned int spellEndCellX; + unsigned int spellEndCellY; + bool spellCheckSelection; + TQStringList replaceAll; + } spell; + + struct + { + Sheet * currentSheet; + Sheet * firstSheet; + } searchInSheets; + + // the tools + struct ToolEntry + { + TQString command; + KDataToolInfo info; + }; + TQPtrList<ToolEntry> toolList; + + void initActions(); + void adjustActions( bool mode ); + void adjustActions( Sheet* sheet, Cell* cell ); + void adjustWorkbookActions( bool mode ); + void updateButton( Cell *cell, int column, int row); + TQButton* newIconButton( const char *_file, bool _kbutton = false, TQWidget *_parent = 0L ); + + PropertyEditor *m_propertyEditor; + + // On timeout this will execute the status bar operation (e.g. SUM). + // This is delayed to speed up the selection. + TQTimer statusBarOpTimer; +}; + +class ViewActions +{ +public: + + // cell formatting + TDEAction* cellLayout; + TDEAction *actionExtraProperties; + TDEAction* defaultFormat; + TDEToggleAction* bold; + TDEToggleAction* italic; + TDEToggleAction* underline; + TDEToggleAction* strikeOut; + TDEFontAction* selectFont; + TDEFontSizeAction* selectFontSize; + TDEAction* fontSizeUp; + TDEAction* fontSizeDown; + TTDESelectColorAction* textColor; + TDEToggleAction* alignLeft; + TDEToggleAction* alignCenter; + TDEToggleAction* alignRight; + TDEToggleAction* alignTop; + TDEToggleAction* alignMiddle; + TDEToggleAction* alignBottom; + TDEToggleAction* wrapText; + TDEToggleAction* verticalText; + TDEAction* increaseIndent; + TDEAction* decreaseIndent; + TDEAction* changeAngle; + TDEToggleAction* percent; + TDEAction* precplus; + TDEAction* precminus; + TDEToggleAction* money; + TDEAction* upper; + TDEAction* lower; + TDEAction* firstLetterUpper; + TTDESelectColorAction* bgColor; + TDEAction* borderLeft; + TDEAction* borderRight; + TDEAction* borderTop; + TDEAction* borderBottom; + TDEAction* borderAll; + TDEAction* borderOutline; + TDEAction* borderRemove; + TTDESelectColorAction* borderColor; + TDESelectAction* selectStyle; + TDEAction* createStyle; + + // cell operations + TDEAction* editCell; + TDEAction* insertCell; + TDEAction* removeCell; + TDEAction* deleteCell; + TDEToolBarPopupAction* mergeCell; + TDEAction* mergeCellHorizontal; + TDEAction* mergeCellVertical; + TDEAction* dissociateCell; + TDEAction* clearText; + TDEAction* conditional; + TDEAction* clearConditional; + TDEAction* validity; + TDEAction* clearValidity; + TDEAction* addModifyComment; + TDEAction* removeComment; + TDEAction* clearComment; + + // column & row operations + TDEAction* resizeColumn; + TDEAction* insertColumn; + TDEAction* deleteColumn; + TDEAction* hideColumn; + TDEAction* showColumn; + TDEAction* equalizeColumn; + TDEAction* showSelColumns; + TDEAction* resizeRow; + TDEAction* insertRow; + TDEAction* deleteRow; + TDEAction* hideRow; + TDEAction* showRow; + TDEAction* equalizeRow; + TDEAction* showSelRows; + TDEAction* adjust; + + // sheet/workbook operations + TDEAction* sheetProperties; + TDEAction* insertSheet; + TDEAction* menuInsertSheet; + TDEAction* removeSheet; + TDEAction* renameSheet; + TDEAction* hideSheet; + TDEAction* showSheet; + TDEAction* autoFormat; + TDEAction* areaName; + TDEAction* showArea; + TDEAction* insertSeries; + TDEAction* insertFunction; + TDEAction* insertSpecialChar; + TDEAction* insertFromDatabase; + TDEAction* insertFromTextfile; + TDEAction* insertFromClipboard; + TDEAction* transform; + TDEAction* sort; + TDEAction* sortDec; + TDEAction* sortInc; + TDEAction* fillRight; + TDEAction* fillLeft; + TDEAction* fillUp; + TDEAction* fillDown; + TDEAction* paperLayout; + TDEAction* definePrintRange; + TDEAction* resetPrintRange; + TDEToggleAction* showPageBorders; + TDEAction* recalcWorksheet; + TDEAction* recalcWorkbook; + TDEToggleAction* protectSheet; + TDEToggleAction* protectDoc; + + // general editing + TDEAction* cut; + TDEAction* copy; + TDEAction* paste; + TDEAction* specialPaste; + TDEAction* insertCellCopy; + TDEAction* find; + TDEAction* replace; + + // navigation + TDEAction* gotoCell; + TDEAction* nextSheet; + TDEAction* prevSheet; + TDEAction* firstSheet; + TDEAction* lastSheet; + + // misc + TDEAction* styleDialog; + TDEAction* autoSum; + TDESelectAction* formulaSelection; + TDEAction* insertLink; + TDEAction* removeLink; + TDEAction* consolidate; + TDEAction* goalSeek; + TDEAction* subTotals; + TDEAction* textToColumns; + TDEAction* multipleOperations; + TDEAction* createTemplate; + KoPartSelectAction *insertPart; + TDEToggleAction* insertChartFrame; + TDEAction* insertPicture; + TDEAction* customList; + TDEAction* spellChecking; + TDEAction* internalTests; + TDEAction* inspector; + + // settings + KoZoomAction* viewZoom; + TDEToggleAction* showStatusBar; + TDEToggleAction* showTabBar; + TDEToggleAction* showFormulaBar; + TDEAction* preference; + + // running calculation + TDEToggleAction* calcNone; + TDEToggleAction* calcMin; + TDEToggleAction* calcMax; + TDEToggleAction* calcAverage; + TDEToggleAction* calcCount; + TDEToggleAction* calcSum; + TDEToggleAction* calcCountA; +}; + + +void View::Private::initActions() +{ + actions = new ViewActions; + + TDEActionCollection* ac = view->actionCollection(); + + // -- cell formatting actions -- + + actions->cellLayout = new TDEAction( i18n("Cell Format..."), "cell_layout", + TQt::CTRL+ TQt::ALT+ TQt::Key_F, TQT_TQOBJECT(view), TQT_SLOT( layoutDlg() ), ac, "cellLayout" ); + actions->cellLayout->setToolTip( i18n("Set the cell formatting.") ); + + actions->actionExtraProperties = new TDEAction( i18n( "&Properties" ), "penbrush", 0, + TQT_TQOBJECT(view), TQT_SLOT( extraProperties() ), ac, "extra_properties" ); + + actions->defaultFormat = new TDEAction( i18n("Default"), + 0, TQT_TQOBJECT(view), TQT_SLOT( defaultSelection() ), ac, "default" ); + actions->defaultFormat->setToolTip( i18n("Resets to the default format.") ); + + actions->bold = new TDEToggleAction( i18n("Bold"), "format-text-bold", + TQt::CTRL+TQt::Key_B, ac, "bold"); + TQT_BASE_OBJECT_NAME::connect( actions->bold, TQT_SIGNAL( toggled( bool) ), + TQT_TQOBJECT(view), TQT_SLOT( bold( bool ) ) ); + + actions->italic = new TDEToggleAction( i18n("Italic"), "format-text-italic", + TQt::CTRL+TQt::Key_I, ac, "italic"); + TQT_BASE_OBJECT_NAME::connect( actions->italic, TQT_SIGNAL( toggled( bool) ), + TQT_TQOBJECT(view), TQT_SLOT( italic( bool ) ) ); + + actions->underline = new TDEToggleAction( i18n("Underline"), "format-text-underline", + TQt::CTRL+TQt::Key_U, ac, "underline"); + TQT_BASE_OBJECT_NAME::connect( actions->underline, TQT_SIGNAL( toggled( bool) ), + TQT_TQOBJECT(view), TQT_SLOT( underline( bool ) ) ); + + actions->strikeOut = new TDEToggleAction( i18n("Strike Out"), "format-text-strikethrough", + 0, ac, "strikeout"); + TQT_BASE_OBJECT_NAME::connect( actions->strikeOut, TQT_SIGNAL( toggled( bool) ), + TQT_TQOBJECT(view), TQT_SLOT( strikeOut( bool ) ) ); + + actions->selectFont = new TDEFontAction( i18n("Select Font..."), + 0, ac, "selectFont" ); + TQT_BASE_OBJECT_NAME::connect( actions->selectFont, TQT_SIGNAL( activated( const TQString& ) ), + TQT_TQOBJECT(view), TQT_SLOT( fontSelected( const TQString& ) ) ); + + actions->selectFontSize = new TDEFontSizeAction( i18n("Select Font Size"), + 0, ac, "selectFontSize" ); + TQT_BASE_OBJECT_NAME::connect( actions->selectFontSize, TQT_SIGNAL( fontSizeChanged( int ) ), + TQT_TQOBJECT(view), TQT_SLOT( fontSizeSelected( int ) ) ); + + actions->fontSizeUp = new TDEAction( i18n("Increase Font Size"), "fontsizeup", + 0, TQT_TQOBJECT(view), TQT_SLOT( increaseFontSize() ), ac, "increaseFontSize" ); + + actions->fontSizeDown = new TDEAction( i18n("Decrease Font Size"), "fontsizedown", + 0, TQT_TQOBJECT(view), TQT_SLOT( decreaseFontSize() ), ac, "decreaseFontSize" ); + + actions->textColor = new TTDESelectColorAction( i18n("Text Color"), + TTDESelectColorAction::TextColor, TQT_TQOBJECT(view), TQT_SLOT( changeTextColor() ), + ac, "textColor",true ); + actions->textColor->setDefaultColor(TQColor()); + + actions->alignLeft = new TDEToggleAction( i18n("Align Left"), "format-text-direction-ltr", + 0, ac, "left"); + TQT_BASE_OBJECT_NAME::connect( actions->alignLeft, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignLeft( bool ) ) ); + actions->alignLeft->setExclusiveGroup( "Align" ); + actions->alignLeft->setToolTip(i18n("Left justify the cell contents.")); + + actions->alignCenter = new TDEToggleAction( i18n("Align Center"), "text_center", + 0, ac, "center"); + TQT_BASE_OBJECT_NAME::connect( actions->alignCenter, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignCenter( bool ) ) ); + actions->alignCenter->setExclusiveGroup( "Align" ); + actions->alignCenter->setToolTip(i18n("Center the cell contents.")); + + actions->alignRight = new TDEToggleAction( i18n("Align Right"), "format-text-direction-rtl", + 0, ac, "right"); + TQT_BASE_OBJECT_NAME::connect( actions->alignRight, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignRight( bool ) ) ); + actions->alignRight->setExclusiveGroup( "Align" ); + actions->alignRight->setToolTip(i18n("Right justify the cell contents.")); + + actions->alignTop = new TDEToggleAction( i18n("Align Top"), "text_top", + 0, ac, "top"); + TQT_BASE_OBJECT_NAME::connect( actions->alignTop, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignTop( bool ) ) ); + actions->alignTop->setExclusiveGroup( "Pos" ); + actions->alignTop->setToolTip(i18n("Align cell contents along the top of the cell.")); + + actions->alignMiddle = new TDEToggleAction( i18n("Align Middle"), "middle", + 0, ac, "middle"); + TQT_BASE_OBJECT_NAME::connect( actions->alignMiddle, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignMiddle( bool ) ) ); + actions->alignMiddle->setExclusiveGroup( "Pos" ); + actions->alignMiddle->setToolTip(i18n("Align cell contents centered in the cell.")); + + actions->alignBottom = new TDEToggleAction( i18n("Align Bottom"), "text_bottom", + 0, ac, "bottom"); + TQT_BASE_OBJECT_NAME::connect( actions->alignBottom, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( alignBottom( bool ) ) ); + actions->alignBottom->setExclusiveGroup( "Pos" ); + actions->alignBottom->setToolTip(i18n("Align cell contents along the bottom of the cell.")); + + actions->wrapText = new TDEToggleAction( i18n("Wrap Text"), "multirow", + 0, ac, "multiRow" ); + TQT_BASE_OBJECT_NAME::connect( actions->wrapText, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( wrapText( bool ) ) ); + actions->wrapText->setToolTip(i18n("Make the cell text wrap onto multiple lines.")); + + actions->verticalText = new TDEToggleAction( i18n("Vertical Text"),"vertical_text" , + 0 ,ac, "verticaltext" ); + TQT_BASE_OBJECT_NAME::connect( actions->verticalText, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( verticalText( bool ) ) ); + actions->verticalText->setToolTip(i18n("Print cell contents vertically.")); + + actions->increaseIndent = new TDEAction( i18n("Increase Indent"), + TQApplication::reverseLayout() ? "format_decreaseindent":"format_increaseindent", + 0, TQT_TQOBJECT(view), TQT_SLOT( increaseIndent() ), ac, "increaseindent" ); + actions->increaseIndent->setToolTip(i18n("Increase the indentation.")); + + actions->decreaseIndent = new TDEAction( i18n("Decrease Indent"), + TQApplication::reverseLayout() ? "format_increaseindent" : "format_decreaseindent", + 0, TQT_TQOBJECT(view), TQT_SLOT( decreaseIndent() ), ac, "decreaseindent"); + actions->decreaseIndent->setToolTip(i18n("Decrease the indentation.")); + + actions->changeAngle = new TDEAction( i18n("Change Angle..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( changeAngle() ), ac, "changeangle" ); + actions->changeAngle->setToolTip(i18n("Change the angle that cell contents are printed.")); + + actions->percent = new TDEToggleAction( i18n("Percent Format"), "percent", + 0, ac, "percent"); + TQT_BASE_OBJECT_NAME::connect( actions->percent, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( percent( bool ) ) ); + actions->percent->setToolTip(i18n("Set the cell formatting to look like a percentage.")); + + actions->precplus = new TDEAction( i18n("Increase Precision"), "prec_plus", + 0, TQT_TQOBJECT(view), TQT_SLOT( precisionPlus() ), ac, "precplus"); + actions->precplus->setToolTip(i18n("Increase the decimal precision shown onscreen.")); + + actions->precminus = new TDEAction( i18n("Decrease Precision"), "prec_minus", + 0, TQT_TQOBJECT(view), TQT_SLOT( precisionMinus() ), ac, "precminus"); + actions->precminus->setToolTip(i18n("Decrease the decimal precision shown onscreen.")); + + actions->money = new TDEToggleAction( i18n("Money Format"), "money", + 0, ac, "money"); + TQT_BASE_OBJECT_NAME::connect( actions->money, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( moneyFormat( bool ) ) ); + actions->money->setToolTip(i18n("Set the cell formatting to look like your local currency.")); + + actions->upper = new TDEAction( i18n("Upper Case"), "fontsizeup", + 0, TQT_TQOBJECT(view), TQT_SLOT( upper() ), ac, "upper" ); + actions->upper->setToolTip(i18n("Convert all letters to upper case.")); + + actions->lower = new TDEAction( i18n("Lower Case"), "fontsizedown", + 0, TQT_TQOBJECT(view), TQT_SLOT( lower() ), ac, "lower" ); + actions->lower->setToolTip(i18n("Convert all letters to lower case.")); + + actions->firstLetterUpper = new TDEAction( i18n("Convert First Letter to Upper Case"), "first_letter_upper", + 0, TQT_TQOBJECT(view), TQT_SLOT( firstLetterUpper() ),ac, "firstletterupper" ); + actions->firstLetterUpper->setToolTip(i18n("Capitalize the first letter.")); + + actions->bgColor = new TTDESelectColorAction( i18n("Background Color"), + TTDESelectColorAction::FillColor, ac, "backgroundColor", true ); + TQT_BASE_OBJECT_NAME::connect(actions->bgColor, TQT_SIGNAL( activated() ), + TQT_TQOBJECT(view), TQT_SLOT( changeBackgroundColor() ) ); + actions->bgColor->setDefaultColor(TQColor()); + actions->bgColor->setToolTip(i18n("Set the background color.")); + + actions->borderLeft = new TDEAction( i18n("Border Left"), "border_left", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderLeft() ), ac, "borderLeft" ); + actions->borderLeft->setToolTip(i18n("Set a left border to the selected area.")); + + actions->borderRight = new TDEAction( i18n("Border Right"), "border_right", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderRight() ), ac, "borderRight" ); + actions->borderRight->setToolTip(i18n("Set a right border to the selected area.")); + + actions->borderTop = new TDEAction( i18n("Border Top"), "border_top", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderTop() ), ac, "borderTop" ); + actions->borderTop->setToolTip(i18n("Set a top border to the selected area.")); + + actions->borderBottom = new TDEAction( i18n("Border Bottom"), "border_bottom", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderBottom() ), ac, "borderBottom" ); + actions->borderBottom->setToolTip(i18n("Set a bottom border to the selected area.")); + + actions->borderAll = new TDEAction( i18n("All Borders"), "border_all", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderAll() ), ac, "borderAll" ); + actions->borderAll->setToolTip(i18n("Set a border around all cells in the selected area.")); + + actions->borderRemove = new TDEAction( i18n("Remove Borders"), "border_remove", + 0, TQT_TQOBJECT(view), TQT_SLOT( borderRemove() ), ac, "borderRemove" ); + actions->borderRemove->setToolTip(i18n("Remove all borders in the selected area.")); + + actions->borderOutline = new TDEAction( i18n("Border Outline"), ("border_outline"), + 0, TQT_TQOBJECT(view), TQT_SLOT( borderOutline() ), ac, "borderOutline" ); + actions->borderOutline->setToolTip(i18n("Set a border to the outline of the selected area.")); + + actions->borderColor = new TTDESelectColorAction( i18n("Border Color"), + TTDESelectColorAction::LineColor, ac, "borderColor" ); + TQT_BASE_OBJECT_NAME::connect( actions->borderColor, TQT_SIGNAL( activated() ), + TQT_TQOBJECT(view), TQT_SLOT( changeBorderColor() ) ); + actions->borderColor->setToolTip( i18n( "Select a new border color." ) ); + + actions->selectStyle = new TDESelectAction( i18n( "St&yle" ), + 0, ac, "stylemenu" ); + actions->selectStyle->setToolTip( i18n( "Apply a predefined style to the selected cells." ) ); + TQT_BASE_OBJECT_NAME::connect( actions->selectStyle, TQT_SIGNAL( activated( const TQString & ) ), + TQT_TQOBJECT(view), TQT_SLOT( styleSelected( const TQString & ) ) ); + + actions->createStyle = new TDEAction( i18n( "Create Style From Cell..." ), + 0, TQT_TQOBJECT(view), TQT_SLOT( createStyleFromCell()), ac, "createStyle" ); + actions->createStyle->setToolTip( i18n( "Create a new style based on the currently selected cell." ) ); + + // -- cell operation actions -- + + actions->editCell = new TDEAction( i18n("Modify Cell"),"cell_edit", + TQt::CTRL+TQt::Key_M, TQT_TQOBJECT(view), TQT_SLOT( editCell() ), ac, "editCell" ); + actions->editCell->setToolTip(i18n("Edit the highlighted cell.")); + + actions->insertCell = new TDEAction( i18n("Insert Cells..."), "insertcell", + 0, TQT_TQOBJECT(view), TQT_SLOT( slotInsert() ), ac, "insertCell" ); + actions->insertCell->setToolTip(i18n("Insert a blank cell into the spreadsheet.")); + + actions->removeCell = new TDEAction( i18n("Remove Cells..."), "removecell", + 0, TQT_TQOBJECT(view), TQT_SLOT( slotRemove() ), ac, "removeCell" ); + actions->removeCell->setToolTip(i18n("Removes the current cell from the spreadsheet.")); + + actions->deleteCell = new TDEAction( i18n("Delete"), "deletecell", + 0, TQT_TQOBJECT(view), TQT_SLOT( deleteSelection() ), ac, "delete" ); + actions->deleteCell->setToolTip(i18n("Delete all contents and formatting of the current cell.")); + + actions->mergeCell = new TDEToolBarPopupAction( i18n("Merge Cells"),"mergecell", + 0, TQT_TQOBJECT(view), TQT_SLOT( mergeCell() ), ac, "mergecell" ); + actions->mergeCell->setToolTip(i18n("Merge the selected region.")); + actions->mergeCell->plug( actions->mergeCell->popupMenu() ); + + actions->mergeCellHorizontal = new TDEAction( i18n("Merge Cells Horizontally"),"mergecell-horizontal", + 0, TQT_TQOBJECT(view), TQT_SLOT( mergeCellHorizontal() ), ac, "mergecellHorizontal" ); + actions->mergeCellHorizontal->setToolTip(i18n("Merge the selected region horizontally.")); + actions->mergeCellHorizontal->plug( actions->mergeCell->popupMenu() ); + + actions->mergeCellVertical = new TDEAction( i18n("Merge Cells Vertically"),"mergecell-vertical", + 0, TQT_TQOBJECT(view), TQT_SLOT( mergeCellVertical() ), ac, "mergecellVertical" ); + actions->mergeCellVertical->setToolTip(i18n("Merge the selected region vertically.")); + actions->mergeCellVertical->plug( actions->mergeCell->popupMenu() ); + + actions->dissociateCell = new TDEAction( i18n("Dissociate Cells"),"dissociatecell", + 0, TQT_TQOBJECT(view), TQT_SLOT( dissociateCell() ), ac, "dissociatecell" ); + actions->dissociateCell->setToolTip(i18n("Unmerge the selected region.")); + + actions->clearText = new TDEAction( i18n("Text"), + 0, TQT_TQOBJECT(view), TQT_SLOT( clearTextSelection() ), ac, "cleartext" ); + actions->clearText->setToolTip(i18n("Remove the contents of the current cell.")); + + actions->conditional = new TDEAction( i18n("Conditional Cell Attributes..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( conditional() ), ac, "conditional" ); + actions->conditional->setToolTip(i18n("Set cell format based on certain conditions.")); + + + actions->clearConditional = new TDEAction( i18n("Conditional Cell Attributes"), + 0, TQT_TQOBJECT(view), TQT_SLOT( clearConditionalSelection() ), ac, "clearconditional" ); + actions->clearConditional->setToolTip(i18n("Remove the conditional cell formatting.")); + + actions->validity = new TDEAction( i18n("Validity..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( validity() ), ac, "validity" ); + actions->validity->setToolTip(i18n("Set tests to confirm cell data is valid.")); + + actions->clearValidity = new TDEAction( i18n("Validity"), + 0, TQT_TQOBJECT(view), TQT_SLOT( clearValiditySelection() ), ac, "clearvalidity" ); + actions->clearValidity->setToolTip(i18n("Remove the validity tests on this cell.")); + + actions->addModifyComment = new TDEAction( i18n("&Add/Modify Comment..."),"comment", + 0, TQT_TQOBJECT(view), TQT_SLOT( addModifyComment() ), ac, "addmodifycomment" ); + actions->addModifyComment->setToolTip(i18n("Edit a comment for this cell.")); + + actions->removeComment = new TDEAction( i18n("&Remove Comment"),"removecomment", + 0, TQT_TQOBJECT(view), TQT_SLOT( removeComment() ), ac, "removecomment" ); + actions->removeComment->setToolTip(i18n("Remove this cell's comment.")); + + actions->clearComment = new TDEAction( i18n("Comment"), + 0, TQT_TQOBJECT(view), TQT_SLOT( clearCommentSelection() ), ac, "clearcomment" ); + actions->clearComment->setToolTip(i18n("Remove this cell's comment.")); + + // -- column & row actions -- + + actions->resizeColumn = new TDEAction( i18n("Resize Column..."), "resizecol", + 0, TQT_TQOBJECT(view), TQT_SLOT( resizeColumn() ), ac, "resizeCol" ); + actions->resizeColumn->setToolTip(i18n("Change the width of a column.")); + + actions->insertColumn = new TDEAction( i18n("Insert Columns"), "insert_table_col", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertColumn() ), ac, "insertColumn" ); + actions->insertColumn->setToolTip(i18n("Inserts a new column into the spreadsheet.")); + + actions->deleteColumn = new TDEAction( i18n("Delete Columns"), "delete_table_col", + 0, TQT_TQOBJECT(view), TQT_SLOT( deleteColumn() ), ac, "deleteColumn" ); + actions->deleteColumn->setToolTip(i18n("Removes a column from the spreadsheet.")); + + actions->hideColumn = new TDEAction( i18n("Hide Columns"), "hide_table_column", + 0, TQT_TQOBJECT(view), TQT_SLOT( hideColumn() ), ac, "hideColumn" ); + actions->hideColumn->setToolTip(i18n("Hide the column from view.")); + + actions->showColumn = new TDEAction( i18n("Show Columns..."), "show_table_column", + 0, TQT_TQOBJECT(view), TQT_SLOT( showColumn() ), ac, "showColumn" ); + actions->showColumn->setToolTip(i18n("Show hidden columns.")); + + actions->equalizeColumn = new TDEAction( i18n("Equalize Column"), "adjustcol", + 0, TQT_TQOBJECT(view), TQT_SLOT( equalizeColumn() ), ac, "equalizeCol" ); + actions->equalizeColumn->setToolTip(i18n("Resizes selected columns to be the same size.")); + + actions->showSelColumns = new TDEAction( i18n("Show Columns"), "show_sheet_column", + 0, TQT_TQOBJECT(view), TQT_SLOT( showSelColumns() ), ac, "showSelColumns" ); + actions->showSelColumns->setToolTip(i18n("Show hidden columns in the selection.")); + actions->showSelColumns->setEnabled(false); + + actions->resizeRow = new TDEAction( i18n("Resize Row..."), "resizerow", + 0, TQT_TQOBJECT(view), TQT_SLOT( resizeRow() ), ac, "resizeRow" ); + actions->resizeRow->setToolTip(i18n("Change the height of a row.")); + + actions->insertRow = new TDEAction( i18n("Insert Rows"), "insert_table_row", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertRow() ), ac, "insertRow" ); + actions->insertRow->setToolTip(i18n("Inserts a new row into the spreadsheet.")); + + actions->deleteRow = new TDEAction( i18n("Delete Rows"), "delete_table_row", + 0, TQT_TQOBJECT(view), TQT_SLOT( deleteRow() ), ac, "deleteRow" ); + actions->deleteRow->setToolTip(i18n("Removes a row from the spreadsheet.")); + + actions->hideRow = new TDEAction( i18n("Hide Rows"), "hide_table_row", + 0, TQT_TQOBJECT(view), TQT_SLOT( hideRow() ), ac, "hideRow" ); + actions->hideRow->setToolTip(i18n("Hide a row from view.")); + + actions->showRow = new TDEAction( i18n("Show Rows..."), "show_table_row", + 0, TQT_TQOBJECT(view), TQT_SLOT( showRow() ), ac, "showRow" ); + actions->showRow->setToolTip(i18n("Show hidden rows.")); + + actions->equalizeRow = new TDEAction( i18n("Equalize Row"), "adjustrow", + 0, TQT_TQOBJECT(view), TQT_SLOT( equalizeRow() ), ac, "equalizeRow" ); + actions->equalizeRow->setToolTip(i18n("Resizes selected rows to be the same size.")); + + actions->showSelRows = new TDEAction( i18n("Show Rows"), "show_table_row", + 0, TQT_TQOBJECT(view), TQT_SLOT( showSelRows() ), ac, "showSelRows" ); + actions->showSelRows->setEnabled(false); + actions->showSelRows->setToolTip(i18n("Show hidden rows in the selection.")); + + actions->adjust = new TDEAction( i18n("Adjust Row && Column"), + 0, TQT_TQOBJECT(view), TQT_SLOT( adjust() ), ac, "adjust" ); + actions->adjust->setToolTip(i18n("Adjusts row/column size so that the contents will fit.")); + + // -- sheet/workbook actions -- + actions->sheetProperties = new TDEAction( i18n("Sheet Properties"), + 0, TQT_TQOBJECT(view), TQT_SLOT( sheetProperties() ), ac, "sheetProperties" ); + actions->sheetProperties->setToolTip(i18n("Modify current sheet's properties.")); + + actions->insertSheet = new TDEAction( i18n("Insert Sheet"),"inserttable", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertSheet() ), ac, "insertSheet" ); + actions->insertSheet->setToolTip(i18n("Insert a new sheet.")); + + // same action as insertSheet, but without 'insert' in the caption + actions->menuInsertSheet = new TDEAction( i18n("&Sheet"),"inserttable", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertSheet() ), ac, "menuInsertSheet" ); + actions->menuInsertSheet->setToolTip(i18n("Insert a new sheet.")); + + actions->removeSheet = new TDEAction( i18n("Remove Sheet"), "delete_table", + 0, TQT_TQOBJECT(view), TQT_SLOT( removeSheet() ), ac, "removeSheet" ); + actions->removeSheet->setToolTip(i18n("Remove the active sheet.")); + + actions->renameSheet=new TDEAction( i18n("Rename Sheet..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( slotRename() ), ac, "renameSheet" ); + actions->renameSheet->setToolTip(i18n("Rename the active sheet.")); + + actions->showSheet = new TDEAction(i18n("Show Sheet..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( showSheet()), ac, "showSheet" ); + actions->showSheet->setToolTip(i18n("Show a hidden sheet.")); + + actions->hideSheet = new TDEAction(i18n("Hide Sheet"), + 0, TQT_TQOBJECT(view), TQT_SLOT( hideSheet() ), ac, "hideSheet" ); + actions->hideSheet->setToolTip(i18n("Hide the active sheet.")); + + actions->autoFormat = new TDEAction( i18n("AutoFormat..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( sheetFormat() ), ac, "sheetFormat" ); + actions->autoFormat->setToolTip(i18n("Set the worksheet formatting.")); + + actions->areaName = new TDEAction( i18n("Area Name..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( setAreaName() ), ac, "areaname" ); + actions->areaName->setToolTip(i18n("Set a name for a region of the spreadsheet.")); + + actions->showArea = new TDEAction( i18n("Show Area..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( showAreaName() ), ac, "showArea" ); + actions->showArea->setToolTip(i18n("Display a named area.")); + + actions->insertFunction = new TDEAction( i18n("&Function..."), "funct", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertMathExpr() ), ac, "insertMathExpr" ); + actions->insertFunction->setToolTip(i18n("Insert math expression.")); + + actions->insertSeries = new TDEAction( i18n("&Series..."),"series", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertSeries() ), ac, "series"); + actions->insertSeries ->setToolTip(i18n("Insert a series.")); + + actions->insertLink = new TDEAction( i18n("&Link..."), "insert_link", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertHyperlink() ), ac, "insertHyperlink" ); + actions->insertLink->setToolTip(i18n("Insert an Internet hyperlink.")); + + actions->removeLink = new TDEAction( i18n("&Remove Link"), + 0, TQT_TQOBJECT(view), TQT_SLOT( removeHyperlink() ), ac, "removeHyperlink" ); + actions->removeLink->setToolTip(i18n("Remove a link.")); + + actions->insertSpecialChar = new TDEAction( i18n( "S&pecial Character..." ), "char", + TQT_TQOBJECT(view), TQT_SLOT( insertSpecialChar() ), ac, "insertSpecialChar" ); + actions->insertSpecialChar->setToolTip( i18n( "Insert one or more symbols or letters not found on the keyboard." ) ); + + actions->insertPart = new KoPartSelectAction( i18n("&Object"), "frame_query", + TQT_TQOBJECT(view), TQT_SLOT( insertObject() ), ac, "insertPart"); + actions->insertPart->setToolTip(i18n("Insert an object from another program.")); + + actions->insertChartFrame = new TDEToggleAction( i18n("&Chart"), "insert_chart", + 0, TQT_TQOBJECT(view), TQT_SLOT( insertChart() ), ac, "insertChart" ); + actions->insertChartFrame->setToolTip(i18n("Insert a chart.")); + + actions->insertPicture = new TDEAction( i18n("&Picture"), + 0, TQT_TQOBJECT(view), TQT_SLOT( insertPicture() ), ac, "insertPicture" ); + actions->insertPicture->setToolTip(i18n("Insert a picture.")); + +#ifndef TQT_NO_SQL + actions->insertFromDatabase = new TDEAction( i18n("From &Database..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( insertFromDatabase() ), ac, "insertFromDatabase"); + actions->insertFromDatabase->setToolTip(i18n("Insert data from a SQL database.")); +#endif + + actions->insertFromTextfile = new TDEAction( i18n("From &Text File..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( insertFromTextfile() ), ac, "insertFromTextfile"); + actions->insertFromTextfile->setToolTip(i18n("Insert data from a text file to the current cursor position/selection.")); + + actions->insertFromClipboard = new TDEAction( i18n("From &Clipboard..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( insertFromClipboard() ), ac, "insertFromClipboard"); + actions->insertFromClipboard->setToolTip(i18n("Insert CSV data from the clipboard to the current cursor position/selection.")); + +// actions->transform = new TDEAction( i18n("Transform Object..."), "rotate", +// 0, TQT_TQOBJECT(view), TQT_SLOT( transformPart() ), ac, "transform" ); +// actions->transform->setToolTip(i18n("Rotate the contents of the cell.")); +// actions->transform->setEnabled( false ); + + actions->sort = new TDEAction( i18n("&Sort..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( sort() ), ac, "sort" ); + actions->sort->setToolTip(i18n("Sort a group of cells.")); + + actions->sortDec = new TDEAction( i18n("Sort &Decreasing"), "sort_decrease", + 0, TQT_TQOBJECT(view), TQT_SLOT( sortDec() ), ac, "sortDec" ); + actions->sortDec->setToolTip(i18n("Sort a group of cells in decreasing (last to first) order.")); + + actions->sortInc = new TDEAction( i18n("Sort &Increasing"), "sort_incr", + 0, TQT_TQOBJECT(view), TQT_SLOT( sortInc() ), ac, "sortInc" ); + actions->sortInc->setToolTip(i18n("Sort a group of cells in ascending (first to last) order.")); + + actions->paperLayout = new TDEAction( i18n("Page Layout..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( paperLayoutDlg() ), ac, "paperLayout" ); + actions->paperLayout->setToolTip(i18n("Specify the layout of the spreadsheet for a printout.")); + + actions->definePrintRange = new TDEAction( i18n("Define Print Range"), + 0, TQT_TQOBJECT(view), TQT_SLOT( definePrintRange() ), ac, "definePrintRange" ); + actions->definePrintRange->setToolTip(i18n("Define the print range in the current sheet.")); + + actions->resetPrintRange = new TDEAction( i18n("Reset Print Range"), + 0, TQT_TQOBJECT(view), TQT_SLOT( resetPrintRange() ), ac, "resetPrintRange" ); + actions->definePrintRange->setToolTip(i18n("Define the print range in the current sheet.")); + + actions->showPageBorders = new TDEToggleAction( i18n("Show Page Borders"), + 0, ac, "showPageBorders"); + actions->showPageBorders->setCheckedState(i18n("Hide Page Borders")); + TQT_BASE_OBJECT_NAME::connect( actions->showPageBorders, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( togglePageBorders( bool ) ) ); + actions->showPageBorders->setToolTip( i18n( "Show on the spreadsheet where the page borders will be." ) ); + + actions->recalcWorksheet = new TDEAction( i18n("Recalculate Sheet"), + TQt::SHIFT + TQt::Key_F9, TQT_TQOBJECT(view), TQT_SLOT( recalcWorkSheet() ), ac, "RecalcWorkSheet" ); + actions->recalcWorksheet->setToolTip(i18n("Recalculate the value of every cell in the current worksheet.")); + + actions->recalcWorkbook = new TDEAction( i18n("Recalculate Document"), + TQt::Key_F9, TQT_TQOBJECT(view), TQT_SLOT( recalcWorkBook() ), ac, "RecalcWorkBook" ); + actions->recalcWorkbook->setToolTip(i18n("Recalculate the value of every cell in all worksheets.")); + + actions->protectSheet = new TDEToggleAction( i18n( "Protect &Sheet..." ), + 0, ac, "protectSheet" ); + actions->protectSheet->setToolTip( i18n( "Protect the sheet from being modified." ) ); + TQT_BASE_OBJECT_NAME::connect( actions->protectSheet, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( toggleProtectSheet( bool ) ) ); + + actions->protectDoc = new TDEToggleAction( i18n( "Protect &Document..." ), + 0, ac, "protectDoc" ); + actions->protectDoc->setToolTip( i18n( "Protect the document from being modified." ) ); + TQT_BASE_OBJECT_NAME::connect( actions->protectDoc, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( toggleProtectDoc( bool ) ) ); + + // -- editing actions -- + + actions->copy = KStdAction::copy( TQT_TQOBJECT(view), TQT_SLOT( copySelection() ), ac, "copy" ); + actions->copy->setToolTip(i18n("Copy the cell object to the clipboard.")); + + actions->paste = KStdAction::paste( TQT_TQOBJECT(view), TQT_SLOT( paste() ), ac, "paste" ); + actions->paste->setToolTip(i18n("Paste the contents of the clipboard at the cursor.")); + + actions->cut = KStdAction::cut( TQT_TQOBJECT(view), TQT_SLOT( cutSelection() ), ac, "cut" ); + actions->cut->setToolTip(i18n("Move the cell object to the clipboard.")); + + actions->specialPaste = new TDEAction( i18n("Special Paste..."), "special_paste", + 0, TQT_TQOBJECT(view), TQT_SLOT( specialPaste() ), ac, "specialPaste" ); + actions->specialPaste->setToolTip(i18n("Paste the contents of the clipboard with special options.")); + + actions->insertCellCopy = new TDEAction( i18n("Paste with Insertion"), "insertcellcopy", + 0, TQT_TQOBJECT(view), TQT_SLOT( slotInsertCellCopy() ), ac, "insertCellCopy" ); + actions->insertCellCopy->setToolTip(i18n("Inserts a cell from the clipboard into the spreadsheet.")); + + actions->find = KStdAction::find( TQT_TQOBJECT(view), TQT_SLOT(find()), ac ); + /*actions->findNext =*/ KStdAction::findNext( TQT_TQOBJECT(view), TQT_SLOT( findNext() ), ac ); + /*actions->findPrevious =*/ KStdAction::findPrev( TQT_TQOBJECT(view), TQT_SLOT( findPrevious() ), ac ); + + actions->replace = KStdAction::replace( TQT_TQOBJECT(view), TQT_SLOT(replace()), ac ); + + actions->fillRight = new TDEAction( i18n( "&Right" ), 0, + 0, TQT_TQOBJECT(view), TQT_SLOT( fillRight() ), ac, "fillRight" ); + + actions->fillLeft = new TDEAction( i18n( "&Left" ), 0, + 0, TQT_TQOBJECT(view), TQT_SLOT( fillLeft() ), ac, "fillLeft" ); + + actions->fillDown = new TDEAction( i18n( "&Down" ), 0, + 0, TQT_TQOBJECT(view), TQT_SLOT( fillDown() ), ac, "fillDown" ); + + actions->fillUp = new TDEAction( i18n( "&Up" ), 0, + 0, TQT_TQOBJECT(view), TQT_SLOT( fillUp() ), ac, "fillUp" ); + + // -- misc actions -- + + actions->styleDialog = new TDEAction( i18n( "Style Manager" ), + 0, TQT_TQOBJECT(view), TQT_SLOT( styleDialog() ), ac, "styles" ); + actions->styleDialog->setToolTip( i18n( "Edit and organize cell styles." ) ); + + actions->autoSum = new TDEAction( i18n("Autosum"), "black_sum", + 0, TQT_TQOBJECT(view), TQT_SLOT( autoSum() ), ac, "autoSum" ); + actions->autoSum->setToolTip(i18n("Insert the 'sum' function")); + + actions->spellChecking = KStdAction::spelling( TQT_TQOBJECT(view), TQT_SLOT( extraSpelling() ), + ac, "spelling" ); + actions->spellChecking->setToolTip(i18n("Check the spelling.")); + + actions->formulaSelection = new TDESelectAction(i18n("Formula Selection"), + 0, ac, "formulaSelection"); + actions->formulaSelection->setToolTip(i18n("Insert a function.")); + TQStringList lst; + lst.append( "SUM"); + lst.append( "AVERAGE"); + lst.append( "IF"); + lst.append( "COUNT"); + lst.append( "MIN"); + lst.append( "MAX"); + lst.append( i18n("Others...") ); + ((TDESelectAction*) actions->formulaSelection)->setItems( lst ); + actions->formulaSelection->setComboWidth( 80 ); + actions->formulaSelection->setCurrentItem(0); + TQT_BASE_OBJECT_NAME::connect( actions->formulaSelection, TQT_SIGNAL( activated( const TQString& ) ), + TQT_TQOBJECT(view), TQT_SLOT( formulaSelection( const TQString& ) ) ); + + actions->viewZoom = new KoZoomAction( i18n( "Zoom" ), "viewmag", 0, ac, "view_zoom" ); + TQT_BASE_OBJECT_NAME::connect( actions->viewZoom, TQT_SIGNAL( zoomChanged( const TQString & ) ), + TQT_TQOBJECT(view), TQT_SLOT( viewZoom( const TQString & ) ) ); + + actions->consolidate = new TDEAction( i18n("&Consolidate..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( consolidate() ), ac, "consolidate" ); + actions->consolidate->setToolTip(i18n("Create a region of summary data from a group of similar regions.")); + + actions->goalSeek = new TDEAction( i18n("&Goal Seek..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( goalSeek() ), ac, "goalSeek" ); + actions->goalSeek->setToolTip( i18n("Repeating calculation to find a specific value.") ); + + actions->subTotals = new TDEAction( i18n("&Subtotals..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( subtotals() ), ac, "subtotals" ); + actions->subTotals->setToolTip( i18n("Create different kind of subtotals to a list or database.") ); + + actions->textToColumns = new TDEAction( i18n("&Text to Columns..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( textToColumns() ), ac, "textToColumns" ); + actions->textToColumns->setToolTip( i18n("Expand the content of cells to multiple columns.") ); + + actions->multipleOperations = new TDEAction( i18n("&Multiple Operations..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( multipleOperations() ), ac, "multipleOperations" ); + actions->multipleOperations->setToolTip( i18n("Apply the same formula to various cells using different values for the parameter.") ); + + actions->createTemplate = new TDEAction( i18n( "&Create Template From Document..." ), + 0, TQT_TQOBJECT(view), TQT_SLOT( createTemplate() ), ac, "createTemplate" ); + + actions->customList = new TDEAction( i18n("Custom Lists..."), + 0, TQT_TQOBJECT(view), TQT_SLOT( sortList() ), ac, "sortlist" ); + actions->customList->setToolTip(i18n("Create custom lists for sorting or autofill.")); + + // -- navigation actions -- + + actions->gotoCell = new TDEAction( i18n("Goto Cell..."),"goto", + 0, TQT_TQOBJECT(view), TQT_SLOT( gotoCell() ), ac, "gotoCell" ); + actions->gotoCell->setToolTip(i18n("Move to a particular cell.")); + + actions->nextSheet = new TDEAction( i18n("Next Sheet"), "forward", + TQt::CTRL+TQt::Key_PageDown, TQT_TQOBJECT(view), TQT_SLOT( nextSheet() ), ac, "nextSheet"); + actions->nextSheet->setToolTip(i18n("Move to the next sheet.")); + + actions->prevSheet = new TDEAction( i18n("Previous Sheet"), "back", + TQt::CTRL+TQt::Key_PageUp, TQT_TQOBJECT(view), TQT_SLOT( previousSheet() ), ac, "previousSheet"); + actions->prevSheet->setToolTip(i18n("Move to the previous sheet.")); + + actions->firstSheet = new TDEAction( i18n("First Sheet"), "go-first", + 0, TQT_TQOBJECT(view), TQT_SLOT( firstSheet() ), ac, "firstSheet"); + actions->firstSheet->setToolTip(i18n("Move to the first sheet.")); + + actions->lastSheet = new TDEAction( i18n("Last Sheet"), "go-last", + 0, TQT_TQOBJECT(view), TQT_SLOT( lastSheet() ), ac, "lastSheet"); + actions->lastSheet->setToolTip(i18n("Move to the last sheet.")); + + // -- settings actions -- + + actions->showStatusBar = new TDEToggleAction( i18n("Show Status Bar"), + 0, ac, "showStatusBar" ); + actions->showStatusBar->setCheckedState(i18n("Hide Status Bar")); + TQT_BASE_OBJECT_NAME::connect( actions->showStatusBar, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( showStatusBar( bool ) ) ); + actions->showStatusBar->setToolTip(i18n("Show the status bar.")); + + actions->showTabBar = new TDEToggleAction( i18n("Show Tab Bar"), + 0, ac, "showTabBar" ); + actions->showTabBar->setCheckedState(i18n("Hide Tab Bar")); + TQT_BASE_OBJECT_NAME::connect( actions->showTabBar, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( showTabBar( bool ) ) ); + actions->showTabBar->setToolTip(i18n("Show the tab bar.")); + + actions->showFormulaBar = new TDEToggleAction( i18n("Show Formula Bar"), + 0, ac, "showFormulaBar" ); + actions->showFormulaBar->setCheckedState(i18n("Hide Formula Bar")); + TQT_BASE_OBJECT_NAME::connect( actions->showFormulaBar, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( showFormulaBar( bool ) ) ); + actions->showFormulaBar->setToolTip(i18n("Show the formula bar.")); + + actions->preference = new TDEAction( i18n("Configure KSpread..."),"configure", + 0, TQT_TQOBJECT(view), TQT_SLOT( preference() ), ac, "preference" ); + actions->preference->setToolTip(i18n("Set various KSpread options.")); + + // -- running calculation actions -- + + actions->calcNone = new TDEToggleAction( i18n("None"), 0, ac, "menu_none"); + TQT_BASE_OBJECT_NAME::connect( actions->calcNone, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcNone->setExclusiveGroup( "Calc" ); + actions->calcNone->setToolTip(i18n("No calculation")); + + actions->calcSum = new TDEToggleAction( i18n("Sum"), 0, ac, "menu_sum"); + TQT_BASE_OBJECT_NAME::connect( actions->calcSum, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcSum->setExclusiveGroup( "Calc" ); + actions->calcSum->setToolTip(i18n("Calculate using sum.")); + + actions->calcMin = new TDEToggleAction( i18n("Min"), 0, ac, "menu_min"); + TQT_BASE_OBJECT_NAME::connect( actions->calcMin, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcMin->setExclusiveGroup( "Calc" ); + actions->calcMin->setToolTip(i18n("Calculate using minimum.")); + + actions->calcMax = new TDEToggleAction( i18n("Max"), 0, ac, "menu_max"); + TQT_BASE_OBJECT_NAME::connect( actions->calcMax, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcMax->setExclusiveGroup( "Calc" ); + actions->calcMax->setToolTip(i18n("Calculate using maximum.")); + + actions->calcAverage = new TDEToggleAction( i18n("Average"), 0, ac, "menu_average"); + TQT_BASE_OBJECT_NAME::connect( actions->calcAverage, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcAverage->setExclusiveGroup( "Calc" ); + actions->calcAverage->setToolTip(i18n("Calculate using average.")); + + actions->calcCount = new TDEToggleAction( i18n("Count"), 0, ac, "menu_count"); + TQT_BASE_OBJECT_NAME::connect( actions->calcCount, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcCount->setExclusiveGroup( "Calc" ); + actions->calcCount->setToolTip(i18n("Calculate using the count.")); + + actions->calcCountA = new TDEToggleAction( i18n("CountA"), 0, ac, "menu_counta"); + TQT_BASE_OBJECT_NAME::connect( actions->calcCountA, TQT_SIGNAL( toggled( bool ) ), + TQT_TQOBJECT(view), TQT_SLOT( menuCalc( bool ) ) ); + actions->calcCountA->setExclusiveGroup( "Calc" ); + actions->calcCountA->setToolTip(i18n("Calculate using the countA.")); + + // -- special action, only for developers -- + + actions->internalTests = new TDEAction( i18n("Run Internal Tests..."), "internalTests", + TQt::CTRL+ TQt::SHIFT + TQt::Key_T, TQT_TQOBJECT(view), TQT_SLOT( runInternalTests() ), ac, "internalTests" ); + actions->inspector = new TDEAction( i18n("Run Inspector..."), "inspector", + TQt::CTRL+ TQt::SHIFT + TQt::Key_I, TQT_TQOBJECT(view), TQT_SLOT( runInspector() ), ac, "inspector" ); + + m_propertyEditor = 0; +} + +void View::Private::adjustActions( bool mode ) +{ + actions->replace->setEnabled( mode ); + actions->insertSeries->setEnabled( mode ); + actions->insertLink->setEnabled( mode ); + actions->insertSpecialChar->setEnabled( mode ); + actions->insertFunction->setEnabled( mode ); + actions->removeComment->setEnabled( mode ); + actions->decreaseIndent->setEnabled( mode ); + actions->bold->setEnabled( mode ); + actions->italic->setEnabled( mode ); + actions->underline->setEnabled( mode ); + actions->strikeOut->setEnabled( mode ); + actions->percent->setEnabled( mode ); + actions->precplus->setEnabled( mode ); + actions->precminus->setEnabled( mode ); + actions->money->setEnabled( mode ); + actions->alignLeft->setEnabled( mode ); + actions->alignCenter->setEnabled( mode ); + actions->alignRight->setEnabled( mode ); + actions->alignTop->setEnabled( mode ); + actions->alignMiddle->setEnabled( mode ); + actions->alignBottom->setEnabled( mode ); + actions->paste->setEnabled( mode ); + actions->cut->setEnabled( mode ); + actions->specialPaste->setEnabled( mode ); + actions->deleteCell->setEnabled( mode ); + actions->clearText->setEnabled( mode ); + actions->clearComment->setEnabled( mode ); + actions->clearValidity->setEnabled( mode ); + actions->clearConditional->setEnabled( mode ); + actions->recalcWorkbook->setEnabled( mode ); + actions->recalcWorksheet->setEnabled( mode ); + actions->adjust->setEnabled( mode ); + actions->editCell->setEnabled( mode ); + actions->paperLayout->setEnabled( mode ); + actions->styleDialog->setEnabled( mode ); + actions->definePrintRange->setEnabled( mode ); + actions->resetPrintRange->setEnabled( mode ); + actions->insertFromDatabase->setEnabled( mode ); + actions->insertFromTextfile->setEnabled( mode ); + actions->insertFromClipboard->setEnabled( mode ); + actions->conditional->setEnabled( mode ); + actions->validity->setEnabled( mode ); + actions->goalSeek->setEnabled( mode ); + actions->subTotals->setEnabled( mode ); + actions->multipleOperations->setEnabled( mode ); + actions->textToColumns->setEnabled( mode ); + actions->consolidate->setEnabled( mode ); + actions->insertCellCopy->setEnabled( mode ); + actions->wrapText->setEnabled( mode ); + actions->selectFont->setEnabled( mode ); + actions->selectFontSize->setEnabled( mode ); + actions->deleteColumn->setEnabled( mode ); + actions->hideColumn->setEnabled( mode ); + actions->showColumn->setEnabled( mode ); + actions->showSelColumns->setEnabled( mode ); + actions->insertColumn->setEnabled( mode ); + actions->deleteRow->setEnabled( mode ); + actions->insertRow->setEnabled( mode ); + actions->hideRow->setEnabled( mode ); + actions->showRow->setEnabled( mode ); + actions->showSelRows->setEnabled( mode ); + actions->formulaSelection->setEnabled( mode ); + actions->textColor->setEnabled( mode ); + actions->bgColor->setEnabled( mode ); + actions->cellLayout->setEnabled( mode ); + actions->borderLeft->setEnabled( mode ); + actions->borderRight->setEnabled( mode ); + actions->borderTop->setEnabled( mode ); + actions->borderBottom->setEnabled( mode ); + actions->borderAll->setEnabled( mode ); + actions->borderOutline->setEnabled( mode ); + actions->borderRemove->setEnabled( mode ); + actions->borderColor->setEnabled( mode ); + actions->removeSheet->setEnabled( mode ); + actions->autoSum->setEnabled( mode ); + actions->defaultFormat->setEnabled( mode ); + actions->areaName->setEnabled( mode ); + actions->resizeRow->setEnabled( mode ); + actions->resizeColumn->setEnabled( mode ); + actions->fontSizeUp->setEnabled( mode ); + actions->fontSizeDown->setEnabled( mode ); + actions->upper->setEnabled( mode ); + actions->lower->setEnabled( mode ); + actions->equalizeRow->setEnabled( mode ); + actions->equalizeColumn->setEnabled( mode ); + actions->verticalText->setEnabled( mode ); + actions->addModifyComment->setEnabled( mode ); + actions->removeComment->setEnabled( mode ); + actions->insertCell->setEnabled( mode ); + actions->removeCell->setEnabled( mode ); + actions->changeAngle->setEnabled( mode ); + actions->dissociateCell->setEnabled( mode ); + actions->increaseIndent->setEnabled( mode ); + actions->decreaseIndent->setEnabled( mode ); + actions->spellChecking->setEnabled( mode ); + actions->calcMin->setEnabled( mode ); + actions->calcMax->setEnabled( mode ); + actions->calcAverage->setEnabled( mode ); + actions->calcCount->setEnabled( mode ); + actions->calcCountA->setEnabled( mode ); + actions->calcSum->setEnabled( mode ); + actions->calcNone->setEnabled( mode ); + actions->insertPart->setEnabled( mode ); + actions->createStyle->setEnabled( mode ); + actions->selectStyle->setEnabled( mode ); + actions->insertChartFrame->setEnabled( mode ); + + actions->autoFormat->setEnabled( false ); + actions->sort->setEnabled( false ); + actions->mergeCell->setEnabled( false ); + actions->mergeCellHorizontal->setEnabled( false ); + actions->mergeCellVertical->setEnabled( false ); + actions->sortDec->setEnabled( false ); + actions->sortInc->setEnabled( false ); +// actions->transform->setEnabled( false ); + + actions->fillRight->setEnabled( false ); + actions->fillLeft->setEnabled( false ); + actions->fillUp->setEnabled( false ); + actions->fillDown->setEnabled( false ); + + if ( mode && !view->doc()->map()->isProtected() ) + actions->renameSheet->setEnabled( true ); + else + actions->renameSheet->setEnabled( false ); + + actions->showStatusBar->setChecked( view->doc()->showStatusBar() ); + actions->showTabBar->setChecked( view->doc()->showTabBar() ); + actions->showFormulaBar->setChecked( view->doc()->showFormulaBar() ); + + formulaButton->setEnabled( mode ); + + if ( activeSheet ) + { + selection->update(); + view->objectSelectedChanged(); + } +} + +void View::Private::adjustActions( Sheet* sheet, Cell* cell ) +{ + if ( sheet->isProtected() && !cell->isDefault() && cell->format()->notProtected( cell->column(), cell->row() ) ) + { + if ( selection->isSingular() ) + { + if ( !actions->bold->isEnabled() ) + adjustActions( true ); + } + else + { + if ( actions->bold->isEnabled() ) + adjustActions( false ); + } + } + else if ( sheet->isProtected() ) + { + if ( actions->bold->isEnabled() ) + adjustActions( false ); + } +} + +void View::Private::adjustWorkbookActions( bool mode ) +{ + tabBar->setReadOnly( !view->doc()->isReadWrite() || view->doc()->map()->isProtected() ); + + actions->hideSheet->setEnabled( mode ); + actions->showSheet->setEnabled( mode ); + actions->insertSheet->setEnabled( mode ); + actions->menuInsertSheet->setEnabled( mode ); + actions->removeSheet->setEnabled( mode ); + + if ( mode ) + { + if ( activeSheet && !activeSheet->isProtected() ) + { + bool state = ( view->doc()->map()->visibleSheets().count() > 1 ); + actions->removeSheet->setEnabled( state ); + actions->hideSheet->setEnabled( state ); + } + actions->showSheet->setEnabled( view->doc()->map()->hiddenSheets().count() > 0 ); + actions->renameSheet->setEnabled( activeSheet && !activeSheet->isProtected() ); + } +} + +// TODO this should be merged with adjustActions +void View::Private::updateButton( Cell *cell, int column, int row) +{ + toolbarLock = true; + + // workaround for bug #59291 (crash upon starting from template) + // certain TQt and Fontconfig combination fail miserably if can not + // find the font name (e.g. not installed in the system) + TQStringList fontList; + TDEFontChooser::getFontList( fontList, 0 ); + TQString fontFamily = cell->format()->textFontFamily( column,row ); + for ( TQStringList::Iterator it = fontList.begin(); it != fontList.end(); ++it ) + if ((*it).lower() == fontFamily.lower()) + { + actions->selectFont->setFont( fontFamily ); + break; + } + + actions->selectFontSize->setFontSize( cell->format()->textFontSize( column, row ) ); + actions->bold->setChecked( cell->format()->textFontBold( column, row ) ); + actions->italic->setChecked( cell->format()->textFontItalic( column, row) ); + actions->underline->setChecked( cell->format()->textFontUnderline( column, row ) ); + actions->strikeOut->setChecked( cell->format()->textFontStrike( column, row ) ); + + actions->alignLeft->setChecked( cell->format()->align( column, row ) == Format::Left ); + actions->alignCenter->setChecked( cell->format()->align( column, row ) == Format::Center ); + actions->alignRight->setChecked( cell->format()->align( column, row ) == Format::Right ); + + actions->alignTop->setChecked( cell->format()->alignY( column, row ) == Format::Top ); + actions->alignMiddle->setChecked( cell->format()->alignY( column, row ) == Format::Middle ); + actions->alignBottom->setChecked( cell->format()->alignY( column, row ) == Format::Bottom ); + + actions->verticalText->setChecked( cell->format()->verticalText( column,row ) ); + + actions->wrapText->setChecked( cell->format()->multiRow( column,row ) ); + + FormatType ft = cell->formatType(); + actions->percent->setChecked( ft == Percentage_format ); + actions->money->setChecked( ft == Money_format ); + + if ( activeSheet && !activeSheet->isProtected() ) + actions->removeComment->setEnabled( !cell->format()->comment(column,row).isEmpty() ); + + if ( activeSheet && !activeSheet->isProtected() ) + actions->decreaseIndent->setEnabled( cell->format()->getIndent( column, row ) > 0.0 ); + + toolbarLock = false; + if ( activeSheet ) + adjustActions( activeSheet, cell ); +} + +TQButton* View::Private::newIconButton( const char *_file, bool _kbutton, TQWidget *_parent ) +{ + if ( _parent == 0L ) + _parent = view; + + if ( !_kbutton ) { + TQPushButton* pb = new TQPushButton( _parent ); + pb->setIconSet( SmallIconSet(_file) ); + return pb; + } else { + TQToolButton* pb = new TQToolButton( _parent ); + pb->setIconSet( SmallIconSet(_file) ); + return pb; + } +} + +KPSheetSelectPage::KPSheetSelectPage( TQWidget *parent ) +: KPrintDialogPage(parent), + gui(new SheetSelectWidget(this)) +{ + setTitle(gui->caption()); + + //disabling automated sorting + gui->ListViewAvailable->setSorting(-1); + gui->ListViewSelected->setSorting(-1); + + //connect buttons + connect(gui->ButtonSelectAll,TQT_SIGNAL(clicked()),this,TQT_SLOT(selectAll())); + connect(gui->ButtonSelect,TQT_SIGNAL(clicked()),this,TQT_SLOT(select())); + connect(gui->ButtonRemove,TQT_SIGNAL(clicked()),this,TQT_SLOT(remove())); + connect(gui->ButtonRemoveAll,TQT_SIGNAL(clicked()),this,TQT_SLOT(removeAll())); + + connect(gui->ButtonMoveTop,TQT_SIGNAL(clicked()),this,TQT_SLOT(moveTop())); + connect(gui->ButtonMoveUp,TQT_SIGNAL(clicked()),this,TQT_SLOT(moveUp())); + connect(gui->ButtonMoveDown,TQT_SIGNAL(clicked()),this,TQT_SLOT(moveDown())); + connect(gui->ButtonMoveBottom,TQT_SIGNAL(clicked()),this,TQT_SLOT(moveBottom())); +} + +// KPSheetSelectPage::~KPSheetSelectPage() +// { +// } + +void KPSheetSelectPage::getOptions( TQMap<TQString,TQString>& opts, bool /*incldef*/ ) +{ + TQStringList sheetlist = this->selectedSheets(); + TQStringList::iterator it; + unsigned int i = 0; + for (it = sheetlist.begin(); it != sheetlist.end(); ++it, i++) + { + opts.insert(printOptionForIndex(i),*it); + } +} + +void KPSheetSelectPage::setOptions( const TQMap<TQString,TQString>& opts ) +{ + unsigned int i = 0; + TQStringList sheetlist; + while (opts.contains(printOptionForIndex(i))) + { + sheetlist.prepend(opts[printOptionForIndex(i++)]); + } + + TQStringList::iterator it; + for (it = sheetlist.begin(); it != sheetlist.end(); ++it) + { + kdDebug() << " adding sheet to list of printed sheets: " << *it << endl; + this->prependSelectedSheet(*it); + } +} + +bool KPSheetSelectPage::isValid(TQString& /*msg*/) +{ + // we print the activeSheet() by default if no sheet is selected, + // so we return true in any case + +// Q_ASSERT(gui); +// if (gui->ListViewSelected->childCount() < 1) +// { +// msg = i18n("No sheets selected for printing!"); +// return false; +// } + return true; +} + +TQString KPSheetSelectPage::printOptionForIndex(unsigned int index) +{ + return TQString("sheetprintorder%1").arg(index); +} + +void KPSheetSelectPage::prependAvailableSheet(const TQString& sheetname) +{ + Q_ASSERT(gui); + new TQListViewItem(gui->ListViewAvailable,sheetname); +} + +void KPSheetSelectPage::prependSelectedSheet(const TQString& sheetname) +{ + Q_ASSERT(gui); + new TQListViewItem(gui->ListViewSelected,sheetname); +} + +TQStringList KPSheetSelectPage::selectedSheets() +{ + Q_ASSERT(gui); + TQStringList list; + TQListViewItem* item = gui->ListViewSelected->firstChild(); + while (item) + { + list.append(item->text(0)); + item = item->nextSibling(); + } + return list; +} + +TQStringList KPSheetSelectPage::selectedSheets(KPrinter &prt) +{ + TQStringList list; + unsigned int index; + const TQMap<TQString,TQString>& options = prt.options(); + for (index = 0; options.contains(KPSheetSelectPage::printOptionForIndex(index)); index++) + { + list.append(options[KPSheetSelectPage::printOptionForIndex(index)]); + } + return list; +} + +void KPSheetSelectPage::clearSelection() +{ + gui->ListViewSelected->clear(); +} + +void KPSheetSelectPage::selectAll() +{ + //we have to add all the stuff in reverse order + // because inserted items (prependSelectedSheet) are prepended + TQStringList list; + TQListViewItem* item = gui->ListViewAvailable->firstChild(); + while (item) + { + list.prepend(item->text(0)); + item = item->nextSibling(); + } + TQStringList::iterator it; + for (it = list.begin(); it != list.end(); ++it) + { + this->prependSelectedSheet(*it); + } +} + +void KPSheetSelectPage::select() +{ + //we have to add all the stuff in reverse order + // because inserted items (prependSelectedSheet) are prepended + TQStringList list; + TQListViewItem* item = gui->ListViewAvailable->firstChild(); + while (item) + { + if (item->isSelected()) + list.prepend(item->text(0)); + item = item->nextSibling(); + } + TQStringList::iterator it; + for (it = list.begin(); it != list.end(); ++it) + { + this->prependSelectedSheet(*it); + } +} + +void KPSheetSelectPage::remove() +{ + TQListViewItem* item = gui->ListViewSelected->firstChild(); + TQListViewItem* nextitem = NULL; + while (item) + { + nextitem = item->nextSibling(); + if (item->isSelected()) + delete item; + item = nextitem; + } +} + +void KPSheetSelectPage::removeAll() +{ + gui->ListViewSelected->clear(); +} + + +void KPSheetSelectPage::moveTop() +{ + //this creates a temporary new list (selected first, then rest) + // which replaces the existing one, to avoid the need of an additional sort column + + TQValueList<TQListViewItem*> newlist; + TQListViewItem* item = gui->ListViewSelected->firstChild(); + TQListViewItem* nextitem = NULL; +// kdDebug() << "Filling new list with selected items first" << endl; + while (item) + { + nextitem = item->nextSibling(); + if (item->isSelected()) + { + newlist.prepend(item); + gui->ListViewSelected->takeItem(item); + } + item = nextitem; + } +// kdDebug() << "Appending the rest" << endl; + item = gui->ListViewSelected->firstChild(); + while (item) + { +// kdDebug() << " processing item " << item->text(0) << endl; + nextitem = item->nextSibling(); + if (!item->isSelected()) + { + newlist.prepend(item); + gui->ListViewSelected->takeItem(item); + } + item = nextitem; + } + +// kdDebug() << "Refill the view with the correctly ordered list" << endl; + //the view is empty now, refill in correct order (reversed!!) + TQValueList<TQListViewItem*>::iterator it; + for (it = newlist.begin(); it != newlist.end(); ++it) + { +// kdDebug() << " adding " << (*it)->text(0) << endl; + gui->ListViewSelected->insertItem(*it); + } +} + +void KPSheetSelectPage::moveUp() +{ + //this creates a temporary new list + // which replaces the existing one, to avoid the need of an additional sort column + + TQValueList<TQListViewItem*> newlist; + TQListViewItem* item = gui->ListViewSelected->firstChild(); + TQListViewItem* nextitem = NULL; + while (item) + { + nextitem = item->nextSibling(); + if (!item->isSelected()) + { + while (nextitem && nextitem->isSelected()) + { + TQListViewItem* nextnextitem = nextitem->nextSibling(); + newlist.prepend(nextitem); + gui->ListViewSelected->takeItem(nextitem); + nextitem = nextnextitem; + } + } + + newlist.prepend(item); + gui->ListViewSelected->takeItem(item); + item = nextitem; + } + +// kdDebug() << "Refill the view with the correctly ordered list" << endl; + //the view is empty now, refill in correct order (reversed!!) + TQValueList<TQListViewItem*>::iterator it; + for (it = newlist.begin(); it != newlist.end(); ++it) + { +// kdDebug() << " adding " << (*it)->text(0) << endl; + gui->ListViewSelected->insertItem(*it); + } +} + +void KPSheetSelectPage::moveDown() +{ + TQListViewItem* item = gui->ListViewSelected->lastItem(); +// while (item) +// { +// nextitem = item->nextSibling(); +// if (previousitem && previousitem->isSelected()) +// { +// previousitem->moveItem(item); +// } +// previousitem = item; +// item = nextitem; +// } + while (item) + { + while (item && !item->isSelected() && item->itemAbove() && item->itemAbove()->isSelected()) + { + TQListViewItem* tempitem = item->itemAbove(); + tempitem->moveItem(item); + } + if (item) + item = item->itemAbove(); + } +} + +void KPSheetSelectPage::moveBottom() +{ + //this creates a temporary new list (unselected first, then rest) + // which replaces the existing one, to avoid the need of an additional sort column + + TQValueList<TQListViewItem*> newlist; + TQListViewItem* item = gui->ListViewSelected->firstChild(); + TQListViewItem* nextitem = NULL; +// kdDebug() << "Filling new list with unselected items first" << endl; + while (item) + { +// kdDebug() << " processing item " << item->text(0) << endl; + nextitem = item->nextSibling(); + if (!item->isSelected()) + { + newlist.prepend(item); + gui->ListViewSelected->takeItem(item); + } + item = nextitem; + } +// kdDebug() << "Appending the rest" << endl; + item = gui->ListViewSelected->firstChild(); + while (item) + { + nextitem = item->nextSibling(); + if (item->isSelected()) + { + newlist.prepend(item); + gui->ListViewSelected->takeItem(item); + } + item = nextitem; + } + +// kdDebug() << "Refill the view with the correctly ordered list" << endl; + //the view is empty now, refill in correct order (reversed!!) + TQValueList<TQListViewItem*>::iterator it; + for (it = newlist.begin(); it != newlist.end(); ++it) + { +// kdDebug() << " adding " << (*it)->text(0) << endl; + gui->ListViewSelected->insertItem(*it); + } +} + + +/***************************************************************************** + * + * View + * + *****************************************************************************/ + +View::View( TQWidget *_parent, const char *_name, + Doc *_doc ) + : KoView( _doc, _parent, _name ) +{ + ElapsedTime et( "View constructor" ); + kdDebug(36001) << "sizeof(Cell)=" << sizeof(Cell) <<endl; + + d = new Private; + d->view = this; + d->doc = _doc; + + d->dcop = 0; + + d->activeSheet = 0; + + d->toolbarLock = false; + d->loading = true; + + d->selection = new Selection( this ); + d->choice = new Selection( this ); + d->choice->setMultipleSelection(true); + connect(d->selection, TQT_SIGNAL(changed(const Region&)), this, TQT_SLOT(slotChangeSelection(const Region&))); + connect(d->choice, TQT_SIGNAL(changed(const Region&)), this, TQT_SLOT(slotChangeChoice(const Region&))); + connect(d->choice, TQT_SIGNAL(changed(const Region&)), this, TQT_SLOT(slotScrollChoice(const Region&))); + + d->findOptions = 0; + d->findLeftColumn = 0; + d->findRightColumn = 0; + d->typeValue = FindOption::Value; + d->directionValue = FindOption::Row; + d->find = 0; + d->replace = 0; + + d->popupMenuFirstToolId = 0; + d->popupMenu = 0; + d->popupColumn = 0; + d->popupRow = 0; + d->popupChild = 0; + d->popupListChoose = 0; + d->popupChildObject = 0; + + d->searchInSheets.currentSheet = 0; + d->searchInSheets.firstSheet = 0; + + // spell-check context + d->spell.tdespell = 0; + d->spell.macroCmdSpellCheck = 0; + d->spell.firstSpellSheet = 0; + d->spell.currentSpellSheet = 0; + d->spell.currentCell = 0; + d->spell.spellStartCellX = 0; + d->spell.spellStartCellY = 0; + d->spell.spellEndCellX = 0; + d->spell.spellEndCellY = 0; + d->spell.spellCheckSelection = false; + + d->insertHandler = 0L; + d->specialCharDlg = 0; + + setInstance( Factory::global() ); + if ( doc()->isReadWrite() ) + setXMLFile( "kspread.rc" ); + else + setXMLFile( "kspread_readonly.rc" ); + + // build the DCOP object + dcopObject(); + + connect( doc()->commandHistory(), TQT_SIGNAL( commandExecuted() ), + this, TQT_SLOT( commandExecuted() ) ); + + // GUI Initializations + initView(); + + d->initActions(); + + + // Handler for moving and resizing embedded parts + KoContainerHandler* h = new KoContainerHandler( this, d->canvas ); + connect( h, TQT_SIGNAL( popupMenu( KoChild*, const TQPoint& ) ), this, TQT_SLOT( popupChildMenu( KoChild*, const TQPoint& ) ) ); + + + connect( this, TQT_SIGNAL( childSelected( KoDocumentChild* ) ), + this, TQT_SLOT( slotChildSelected( KoDocumentChild* ) ) ); + connect( this, TQT_SIGNAL( childUnselected( KoDocumentChild* ) ), + this, TQT_SLOT( slotChildUnselected( KoDocumentChild* ) ) ); + // If a selected part becomes active this is like it is deselected + // just before. + connect( this, TQT_SIGNAL( childActivated( KoDocumentChild* ) ), + this, TQT_SLOT( slotChildUnselected( KoDocumentChild* ) ) ); + + connect( d->canvas, TQT_SIGNAL( objectSelectedChanged() ), + this, TQT_SLOT( objectSelectedChanged() ) ); + + TQT_BASE_OBJECT_NAME::connect( doc()->map(), TQT_SIGNAL( sig_addSheet( Sheet* ) ), TQT_SLOT( slotAddSheet( Sheet* ) ) ); + + TQT_BASE_OBJECT_NAME::connect( doc(), TQT_SIGNAL( sig_refreshView( ) ), this, TQT_SLOT( slotRefreshView() ) ); + + TQT_BASE_OBJECT_NAME::connect( doc(), TQT_SIGNAL( sig_refreshLocale() ), this, TQT_SLOT( refreshLocale())); + + TQT_BASE_OBJECT_NAME::connect( doc(), TQT_SIGNAL( sig_addAreaName( const TQString & ) ), d->posWidget, TQT_SLOT( slotAddAreaName( const TQString & ) ) ); + + TQT_BASE_OBJECT_NAME::connect( doc(), TQT_SIGNAL( sig_removeAreaName( const TQString & ) ), d->posWidget, TQT_SLOT( slotRemoveAreaName( const TQString & ) ) ); + + TQT_BASE_OBJECT_NAME::connect( doc(), TQT_SIGNAL( damagesFlushed( const TQValueList<Damage*>& ) ), + this, TQT_SLOT( handleDamages( const TQValueList<Damage*>& ) ) ); + + //KoView::setZoom( doc()->zoomedResolutionY() /* KoView only supports one zoom */ ); // initial value + //when kspread is embedded into konqueror apply a zoom=100 + //in konqueror we can't change zoom -- ### TODO ? + if (!doc()->isReadWrite()) + { + setZoom( 100, true ); + } + + viewZoom( TQString::number( doc()->zoom() ) ); + + // ## Might be wrong, if doc isn't loaded yet + d->actions->selectStyle->setItems( d->doc->styleManager()->styleNames() ); + + // Delay the setting of the initial position, because + // we have to wait for the widget to be shown. Otherwise, + // we get a wrong widget size. + // This is the last operation for the "View loading" process. + // The loading flag will be unset at its end. + if ( !doc()->map()->sheetList().isEmpty() ) + TQTimer::singleShot(50, this, TQT_SLOT(initialPosition())); + + connect (&d->statusBarOpTimer, TQT_SIGNAL(timeout()), this, TQT_SLOT(calcStatusBarOp())); +} + +View::~View() +{ + // ElapsedTime el( "~View" ); + if ( doc()->isReadWrite() ) // make sure we're not embedded in Konq + deleteEditor( true ); + if ( !d->transformToolBox.isNull() ) + delete (&*d->transformToolBox); + /*if (d->calcLabel) + { + disconnect(d->calcLabel,TQT_SIGNAL(pressed( int )),this,TQT_SLOT(statusBarClicked(int))); + + }*/ + + delete d->spell.tdespell; + + d->canvas->endChoose(); + d->activeSheet = 0; // set the active sheet to 0L so that when during destruction + // of embedded child documents possible repaints in Sheet are not + // performed. The repains can happen if you delete an embedded document, + // which leads to an regionInvalidated() signal emission in KoView, which calls + // repaint, etc.etc. :-) (Simon) + + delete d->selection; + delete d->choice; + + delete d->popupColumn; + delete d->popupRow; + delete d->popupMenu; + delete d->popupChild; + delete d->popupListChoose; + delete d->calcLabel; + delete d->dcop; + + delete d->insertHandler; + d->insertHandler = 0L; + + delete d->actions; + // NOTE Stefan: Delete the Canvas explicitly, even if it has this view as + // parent. Otherwise, it leads to crashes, because it tries to + // access this View in some events (Bug #126492). + delete d->canvas; + delete d; +} + +Doc* View::doc() const +{ + return d->doc; +} + +// should be called only once, from the constructor + /* + * Top part is the formula bar. + * Central part is the canvas, row header and vertical scrollbar. + * Bottom part is the tab bar and horizontal scrollbar. + * + * Note that canvas must the one to be created, since other + * widgets might depend on it. + */ + +void View::initView() +{ + d->viewLayout = new TQGridLayout( this, 3, 4 ); + + // Vert. Scroll Bar + d->calcLabel = 0; + d->vertScrollBar = new TQScrollBar( this, "ScrollBar_2" ); + d->vertScrollBar->setRange( 0, 4096 ); + d->vertScrollBar->setOrientation( Qt::Vertical ); + d->vertScrollBar->setLineStep(60); //just random guess based on what feels okay + d->vertScrollBar->setPageStep(60); //This should be controlled dynamically, depending on how many rows are shown + + // Edit Bar + d->toolWidget = new TQFrame( this ); + + d->formulaBarLayout = new TQHBoxLayout( d->toolWidget ); + d->formulaBarLayout->setMargin( 4 ); + d->formulaBarLayout->addSpacing( 2 ); + + d->posWidget = new ComboboxLocationEditWidget( d->toolWidget, this ); + d->posWidget->setMinimumWidth( 100 ); + d->formulaBarLayout->addWidget( d->posWidget ); + d->formulaBarLayout->addSpacing( 6 ); + + d->formulaButton = d->newIconButton( "funct", true, d->toolWidget ); + d->formulaBarLayout->addWidget( d->formulaButton ); + d->formulaBarLayout->addSpacing( 2 ); + connect( d->formulaButton, TQT_SIGNAL( clicked() ), TQT_SLOT( insertMathExpr() ) ); + + d->cancelButton = d->newIconButton( "cancel", true, d->toolWidget ); + d->formulaBarLayout->addWidget( d->cancelButton ); + d->okButton = d->newIconButton( "ok", true, d->toolWidget ); + d->formulaBarLayout->addWidget( d->okButton ); + d->formulaBarLayout->addSpacing( 6 ); + + // The widget on which we display the sheet + d->canvas = new Canvas( this ); + + // The line-editor that appears above the sheet and allows to + // edit the cells content. It knows about the two buttons. + d->editWidget = new EditWidget( d->toolWidget, d->canvas, d->cancelButton, d->okButton ); + d->editWidget->setFocusPolicy( TQ_StrongFocus ); + d->formulaBarLayout->addWidget( d->editWidget, 2 ); + d->formulaBarLayout->addSpacing( 2 ); + + d->canvas->setEditWidget( d->editWidget ); + + d->hBorderWidget = new HBorder( this, d->canvas,this ); + d->vBorderWidget = new VBorder( this, d->canvas ,this ); + d->hBorderWidget->setSizePolicy( TQSizePolicy::Expanding, TQSizePolicy::Minimum ); + d->vBorderWidget->setSizePolicy( TQSizePolicy::Minimum, TQSizePolicy::Expanding ); + + d->canvas->setFocusPolicy( TQ_StrongFocus ); + TQWidget::setFocusPolicy( TQ_StrongFocus ); + setFocusProxy( d->canvas ); + + connect( this, TQT_SIGNAL( invalidated() ), d->canvas, TQT_SLOT( update() ) ); + + TQWidget* bottomPart = new TQWidget( this ); + d->tabScrollBarLayout = new TQHBoxLayout( bottomPart ); + d->tabScrollBarLayout->setAutoAdd( true ); + d->tabBar = new KoTabBar( bottomPart ); + d->horzScrollBar = new TQScrollBar( bottomPart, "ScrollBar_1" ); + + d->horzScrollBar->setRange( 0, 4096 ); + d->horzScrollBar->setOrientation( Qt::Horizontal ); + + d->horzScrollBar->setLineStep(60); //just random guess based on what feels okay + d->horzScrollBar->setPageStep(60); + + TQT_BASE_OBJECT_NAME::connect( d->tabBar, TQT_SIGNAL( tabChanged( const TQString& ) ), this, TQT_SLOT( changeSheet( const TQString& ) ) ); + TQT_BASE_OBJECT_NAME::connect( d->tabBar, TQT_SIGNAL( tabMoved( unsigned, unsigned ) ), + this, TQT_SLOT( moveSheet( unsigned, unsigned ) ) ); + TQT_BASE_OBJECT_NAME::connect( d->tabBar, TQT_SIGNAL( contextMenu( const TQPoint& ) ), + this, TQT_SLOT( popupTabBarMenu( const TQPoint& ) ) ); + TQT_BASE_OBJECT_NAME::connect( d->tabBar, TQT_SIGNAL( doubleClicked() ), + this, TQT_SLOT( slotRename() ) ); + + d->viewLayout->setColStretch( 1, 10 ); + d->viewLayout->setRowStretch( 2, 10 ); + d->viewLayout->addMultiCellWidget( d->toolWidget, 0, 0, 0, 2 ); + d->viewLayout->addMultiCellWidget( d->hBorderWidget, 1, 1, 1, 2 ); + d->viewLayout->addWidget( d->vBorderWidget, 2, 0 ); + d->viewLayout->addWidget( d->canvas, 2, 1 ); + d->viewLayout->addWidget( d->vertScrollBar, 2, 2 ); + d->viewLayout->addMultiCellWidget( bottomPart, 3, 3, 0, 2 ); + + KStatusBar * sb = statusBar(); + Q_ASSERT(sb); + d->calcLabel = sb ? new KStatusBarLabel( TQString(), 0, sb ) : 0; + addStatusBarItem( d->calcLabel, 0 ); + if (d->calcLabel) + connect(d->calcLabel ,TQT_SIGNAL(itemPressed( int )),this,TQT_SLOT(statusBarClicked(int))); + + // signal slot + TQT_BASE_OBJECT_NAME::connect( d->vertScrollBar, TQT_SIGNAL( valueChanged(int) ), d->canvas, TQT_SLOT( slotScrollVert(int) ) ); + TQT_BASE_OBJECT_NAME::connect( d->horzScrollBar, TQT_SIGNAL( valueChanged(int) ), d->canvas, TQT_SLOT( slotScrollHorz(int) ) ); + +} + +Canvas* View::canvasWidget() const +{ + return d->canvas; +} + +HBorder* View::hBorderWidget()const +{ + return d->hBorderWidget; +} + +VBorder* View::vBorderWidget()const +{ + return d->vBorderWidget; +} + +TQScrollBar* View::horzScrollBar()const +{ + return d->horzScrollBar; +} + +TQScrollBar* View::vertScrollBar()const +{ + return d->vertScrollBar; +} + +EditWidget* View::editWidget()const +{ + return d->editWidget; +} + +ComboboxLocationEditWidget* View::posWidget()const +{ + return d->posWidget; +} + +KoTabBar* View::tabBar() const +{ + return d->tabBar; +} + +bool View::isLoading() const +{ + return d->loading; +} + +Selection* View::selectionInfo() const +{ + return d->selection; +} + +Selection* View::choice() const +{ + return d->choice; +} + +void View::resetInsertHandle() +{ + d->actions->insertChartFrame->setChecked( false ); + // d->actions->insertPicture->setChecked( false ); + + d->insertHandler = 0; +} + +bool View::isInsertingObject() +{ + return d->insertHandler; +} + +const Sheet* View::activeSheet() const +{ + return d->activeSheet; +} + +Sheet* View::activeSheet() +{ + return d->activeSheet; +} + +void View::initConfig() +{ + TDEConfig *config = Factory::global()->config(); + if ( config->hasGroup("Parameters" )) + { + config->setGroup( "Parameters" ); + if ( !doc()->configLoadFromFile() ) + doc()->setShowHorizontalScrollBar(config->readBoolEntry("Horiz ScrollBar",true)); + if ( !doc()->configLoadFromFile() ) + doc()->setShowVerticalScrollBar(config->readBoolEntry("Vert ScrollBar",true)); + doc()->setShowColHeader(config->readBoolEntry("Column Header",true)); + doc()->setShowRowHeader(config->readBoolEntry("Row Header",true)); + if ( !doc()->configLoadFromFile() ) + doc()->setCompletionMode((TDEGlobalSettings::Completion)config->readNumEntry("Completion Mode",(int)(TDEGlobalSettings::CompletionAuto))); + doc()->setMoveToValue((KSpread::MoveTo)config->readNumEntry("Move",(int)(Bottom))); + doc()->setIndentValue( config->readDoubleNumEntry( "Indent", 10.0 ) ); + doc()->setTypeOfCalc((MethodOfCalc)config->readNumEntry("Method of Calc",(int)(SumOfNumber))); + if ( !doc()->configLoadFromFile() ) + doc()->setShowTabBar(config->readBoolEntry("Tabbar",true)); + + doc()->setShowMessageError(config->readBoolEntry( "Msg error" ,false) ); + + doc()->setShowFormulaBar(config->readBoolEntry("Formula bar",true)); + doc()->setShowStatusBar(config->readBoolEntry("Status bar",true)); + + changeNbOfRecentFiles(config->readNumEntry("NbRecentFile",10)); + //autosave value is stored as a minute. + //but default value is stored as seconde. + doc()->setAutoSave(config->readNumEntry("AutoSave",KoDocument::defaultAutoSave()/60)*60); + doc()->setBackupFile( config->readBoolEntry("BackupFile",true)); + } + + if ( config->hasGroup("KSpread Color" ) ) + { + config->setGroup( "KSpread Color" ); + TQColor _col(TQt::lightGray); + _col = config->readColorEntry("GridColor", &_col); + doc()->setGridColor(_col); + + TQColor _pbCol(TQt::red); + _pbCol = config->readColorEntry("PageBorderColor", &_pbCol); + doc()->changePageBorderColor(_pbCol); + } + +// Do we need a Page Layout in the congiguration file? Isn't this already in the template? Philipp +/* +if ( config->hasGroup("KSpread Page Layout" ) ) + { + config->setGroup( "KSpread Page Layout" ); + if ( d->activeSheet->isEmpty()) + { + d->activeSheet->setPaperFormat((KoFormat)config->readNumEntry("Default size page",1)); + + d->activeSheet->setPaperOrientation((KoOrientation)config->readNumEntry("Default orientation page",0)); + d->activeSheet->setPaperUnit((KoUnit::Unit)config->readNumEntry("Default unit page",0)); + } + } +*/ + + initCalcMenu(); + calcStatusBarOp(); +} + +void View::changeNbOfRecentFiles(int _nb) +{ + if (shell()) + shell()->setMaxRecentItems( _nb ); +} + +void View::initCalcMenu() +{ + switch( doc()->getTypeOfCalc()) + { + case SumOfNumber: + d->actions->calcSum->setChecked(true); + break; + case Min: + d->actions->calcMin->setChecked(true); + break; + case Max: + d->actions->calcMax->setChecked(true); + break; + case Average: + d->actions->calcAverage->setChecked(true); + break; + case Count: + d->actions->calcCount->setChecked(true); + break; + case CountA: + d->actions->calcCountA->setChecked(true); + break; + case NoneCalc: + d->actions->calcNone->setChecked(true); + break; + default : + d->actions->calcSum->setChecked(true); + break; + } + +} + + +void View::recalcWorkBook() +{ + if (!activeSheet()) + return; + + Sheet * tbl; + doc()->emitBeginOperation( true ); + for ( tbl = doc()->map()->firstSheet(); + tbl != 0L; + tbl = doc()->map()->nextSheet() ) + { + // bool b = tbl->getAutoCalc(); + // tbl->setAutoCalc( true ); + tbl->recalc( /*force recalculation = */ true); + // tbl->setAutoCalc( b ); + } + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::refreshLocale() +{ + doc()->emitBeginOperation(true); + Sheet *tbl; + for ( tbl = doc()->map()->firstSheet(); + tbl != 0L; + tbl = doc()->map()->nextSheet() ) + { + tbl->updateLocale(); + } + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::recalcWorkSheet() +{ + if ( d->activeSheet != 0 ) + { + doc()->emitBeginOperation( true ); +// bool b = d->activeSheet->getAutoCalc(); +// d->activeSheet->setAutoCalc( true ); + d->activeSheet->recalc( /*force recalculation = */ true); + // d->activeSheet->setAutoCalc( b ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + + +void View::extraSpelling() +{ + if ( d->spell.tdespell ) + return; // Already in progress + + if (d->activeSheet == 0L) + return; + + d->spell.macroCmdSpellCheck = 0L; + d->spell.firstSpellSheet = d->activeSheet; + d->spell.currentSpellSheet = d->spell.firstSpellSheet; + + TQRect selection = d->selection->selection(); + + // if nothing is selected, check every cell + if (d->selection->isSingular()) + { + d->spell.spellStartCellX = 0; + d->spell.spellStartCellY = 0; + d->spell.spellEndCellX = 0; + d->spell.spellEndCellY = 0; + d->spell.spellCheckSelection = false; + d->spell.currentCell = d->activeSheet->firstCell(); + } + else + { + d->spell.spellStartCellX = selection.left(); + d->spell.spellStartCellY = selection.top(); + d->spell.spellEndCellX = selection.right(); + d->spell.spellEndCellY = selection.bottom(); + d->spell.spellCheckSelection = true; + d->spell.currentCell = 0L; + + // "-1" because X gets increased every time we go into spellCheckReady() + d->spell.spellCurrCellX = d->spell.spellStartCellX - 1; + d->spell.spellCurrCellY = d->spell.spellStartCellY; + } + + startKSpell(); +} + + +void View::startKSpell() +{ + if ( doc()->getKSpellConfig() ) + { + doc()->getKSpellConfig()->setIgnoreList( doc()->spellListIgnoreAll() ); + doc()->getKSpellConfig()->setReplaceAllList( d->spell.replaceAll ); + + } + d->spell.tdespell = new KSpell( this, i18n( "Spell Checking" ), TQT_TQOBJECT(this), + TQT_SLOT( spellCheckerReady() ), + doc()->getKSpellConfig() ); + + d->spell.tdespell->setIgnoreUpperWords( doc()->dontCheckUpperWord() ); + d->spell.tdespell->setIgnoreTitleCase( doc()->dontCheckTitleCase() ); + + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( death() ), + this, TQT_SLOT( spellCheckerFinished() ) ); + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( misspelling( const TQString &, + const TQStringList &, + unsigned int) ), + this, TQT_SLOT( spellCheckerMisspelling( const TQString &, + const TQStringList &, + unsigned int) ) ); + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( corrected( const TQString &, + const TQString &, + unsigned int) ), + this, TQT_SLOT( spellCheckerCorrected( const TQString &, + const TQString &, + unsigned int ) ) ); + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( done( const TQString & ) ), + this, TQT_SLOT( spellCheckerDone( const TQString & ) ) ); + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( ignoreall (const TQString & ) ), + this, TQT_SLOT( spellCheckerIgnoreAll( const TQString & ) ) ); + + TQT_BASE_OBJECT_NAME::connect( d->spell.tdespell, TQT_SIGNAL( replaceall( const TQString & , const TQString & )), this, TQT_SLOT( spellCheckerReplaceAll( const TQString & , const TQString & ))); + +} + +void View::spellCheckerReplaceAll( const TQString &orig, const TQString & replacement) +{ + d->spell.replaceAll.append( orig); + d->spell.replaceAll.append( replacement); +} + + +void View::spellCheckerIgnoreAll( const TQString & word) +{ + doc()->addIgnoreWordAll( word ); +} + + +void View::spellCheckerReady() +{ + if (d->canvas) + d->canvas->setCursor( WaitCursor ); + + // go on to the next cell + if (!d->spell.spellCheckSelection) + { + // if nothing is selected we have to check every cell + // we use a different way to make it faster + while ( d->spell.currentCell ) + { + // check text only + if ( d->spell.currentCell->value().isString() ) + { + d->spell.tdespell->check( d->spell.currentCell->text(), true ); + + return; + } + + d->spell.currentCell = d->spell.currentCell->nextCell(); + if ( d->spell.currentCell && d->spell.currentCell->isDefault() ) + kdDebug() << "checking default cell!!" << endl << endl; + } + + if (spellSwitchToOtherSheet()) + spellCheckerReady(); + else + spellCleanup(); + + return; + } + + // if something is selected: + + ++d->spell.spellCurrCellX; + if (d->spell.spellCurrCellX > d->spell.spellEndCellX) + { + d->spell.spellCurrCellX = d->spell.spellStartCellX; + ++d->spell.spellCurrCellY; + } + + unsigned int y; + unsigned int x; + + for ( y = d->spell.spellCurrCellY; y <= d->spell.spellEndCellY; ++y ) + { + for ( x = d->spell.spellCurrCellX; x <= d->spell.spellEndCellX; ++x ) + { + Cell * cell = d->spell.currentSpellSheet->cellAt( x, y ); + + // check text only + if (cell->isDefault() || !cell->value().isString()) + continue; + + d->spell.spellCurrCellX = x; + d->spell.spellCurrCellY = y; + + d->spell.tdespell->check( cell->text(), true ); + + return; + } + d->spell.spellCurrCellX = d->spell.spellStartCellX; + } + + // if the user selected something to be checked we are done + // otherwise ask for checking the next sheet if any + if (d->spell.spellCheckSelection) + { + // Done + spellCleanup(); + } + else + { + if (spellSwitchToOtherSheet()) + spellCheckerReady(); + else + spellCleanup(); + } +} + + +void View::spellCleanup() +{ + if ( d->canvas ) + d->canvas->setCursor( ArrowCursor ); + + d->spell.tdespell->cleanUp(); + delete d->spell.tdespell; + d->spell.tdespell = 0L; + d->spell.firstSpellSheet = 0L; + d->spell.currentSpellSheet = 0L; + d->spell.currentCell = 0L; + d->spell.replaceAll.clear(); + + + KMessageBox::information( this, i18n( "Spell checking is complete." ) ); + + if ( d->spell.macroCmdSpellCheck ) + doc()->addCommand( d->spell.macroCmdSpellCheck ); + d->spell.macroCmdSpellCheck=0L; +} + + +bool View::spellSwitchToOtherSheet() +{ + // there is no other sheet + if ( doc()->map()->count() == 1 ) + return false; + + // for optimization + TQPtrList<Sheet> sheetList = doc()->map()->sheetList(); + + unsigned int curIndex = sheetList.findRef(d->spell.currentSpellSheet); + ++curIndex; + + // last sheet? then start at the beginning + if ( curIndex >= sheetList.count() ) + d->spell.currentSpellSheet = sheetList.first(); + else + d->spell.currentSpellSheet = sheetList.at(curIndex); + + // if the current sheet is the first one again, we are done. + if ( d->spell.currentSpellSheet == d->spell.firstSpellSheet ) + { + setActiveSheet( d->spell.firstSpellSheet ); + return false; + } + + if (d->spell.spellCheckSelection) + { + d->spell.spellEndCellX = d->spell.currentSpellSheet->maxColumn(); + d->spell.spellEndCellY = d->spell.currentSpellSheet->maxRow(); + + d->spell.spellCurrCellX = d->spell.spellStartCellX - 1; + d->spell.spellCurrCellY = d->spell.spellStartCellY; + } + else + { + d->spell.currentCell = d->spell.currentSpellSheet->firstCell(); + } + + if ( KMessageBox::questionYesNo( this, + i18n( "Do you want to check the spelling in the next sheet?") ) + != KMessageBox::Yes ) + return false; + + setActiveSheet( d->spell.currentSpellSheet ); + + return true; +} + + +void View::spellCheckerMisspelling( const TQString &, + const TQStringList &, + unsigned int ) +{ + // scroll to the cell + if ( !d->spell.spellCheckSelection ) + { + d->spell.spellCurrCellX = d->spell.currentCell->column(); + d->spell.spellCurrCellY = d->spell.currentCell->row(); + } + + d->selection->initialize(TQPoint(d->spell.spellCurrCellX, d->spell.spellCurrCellY)); +} + + +void View::spellCheckerCorrected( const TQString & old, const TQString & corr, + unsigned int pos ) +{ + Cell * cell; + + if (d->spell.spellCheckSelection) + { + cell = d->spell.currentSpellSheet->cellAt( d->spell.spellCurrCellX, + d->spell.spellCurrCellY ); + } + else + { + cell = d->spell.currentCell; + d->spell.spellCurrCellX = cell->column(); + d->spell.spellCurrCellY = cell->row(); + } + + Q_ASSERT( cell ); + if ( !cell ) + return; + + doc()->emitBeginOperation(false); + TQString content( cell->text() ); + + UndoSetText* undo = new UndoSetText( doc(), d->activeSheet, + content, + d->spell.spellCurrCellX, + d->spell.spellCurrCellY, + cell->formatType()); + content.replace( pos, old.length(), corr ); + cell->setCellText( content ); + d->editWidget->setText( content ); + + if ( !d->spell.macroCmdSpellCheck ) + d->spell.macroCmdSpellCheck = new MacroUndoAction( doc(), i18n("Correct Misspelled Word") ); + d->spell.macroCmdSpellCheck->addCommand( undo ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::spellCheckerDone( const TQString & ) +{ + int result = d->spell.tdespell->dlgResult(); + + d->spell.tdespell->cleanUp(); + delete d->spell.tdespell; + d->spell.tdespell = 0L; + + if ( result != KS_CANCEL && result != KS_STOP ) + { + if (d->spell.spellCheckSelection) + { + if ( (d->spell.spellCurrCellY <= d->spell.spellEndCellY) + && (d->spell.spellCurrCellX <= d->spell.spellEndCellX) ) + { + startKSpell(); + return; + } + } + else + { + if ( d->spell.currentCell ) + { + d->spell.currentCell = d->spell.currentCell->nextCell(); + + startKSpell(); + + return; + } + } + } + d->spell.replaceAll.clear(); + + if ( d->spell.macroCmdSpellCheck ) + { + doc()->addCommand( d->spell.macroCmdSpellCheck ); + } + d->spell.macroCmdSpellCheck=0L; +} + +void View::spellCheckerFinished() +{ + if (d->canvas) + d->canvas->setCursor( ArrowCursor ); + + KSpell::spellStatus status = d->spell.tdespell->status(); + d->spell.tdespell->cleanUp(); + delete d->spell.tdespell; + d->spell.tdespell = 0L; + d->spell.replaceAll.clear(); + + bool tdespellNotConfigured=false; + + if (status == KSpell::Error) + { + KMessageBox::sorry(this, i18n("ISpell could not be started.\n" + "Please make sure you have ISpell properly configured and in your PATH.")); + tdespellNotConfigured=true; + } + else if (status == KSpell::Crashed) + { + KMessageBox::sorry(this, i18n("ISpell seems to have crashed.")); + } + + if (d->spell.macroCmdSpellCheck) + { + doc()->addCommand( d->spell.macroCmdSpellCheck ); + } + d->spell.macroCmdSpellCheck=0L; + + + if (tdespellNotConfigured) + { + PreferenceDialog configDlg( this, 0 ); + configDlg.openPage( PreferenceDialog::KS_SPELLING); + configDlg.exec(); + } +} + +void View::initialPosition() +{ + // Loading completed, pick initial worksheet + TQPtrListIterator<Sheet> it( doc()->map()->sheetList() ); + for( ; it.current(); ++it ) + addSheet( it.current() ); + + // Set the initial X and Y offsets for the view (OpenDocument loading) + if ( KSPLoadingInfo* loadingInfo = doc()->loadingInfo() ) + { + d->savedAnchors = loadingInfo->cursorPositions(); + d->savedMarkers = loadingInfo->cursorPositions(); + d->savedOffsets = loadingInfo->scrollingOffsets(); + } + + Sheet * tbl = 0L; + if ( doc()->isEmbedded() ) + { + tbl = doc()->displaySheet(); + } + + if ( !tbl ) + tbl = doc()->map()->initialActiveSheet(); + if ( tbl ) + setActiveSheet( tbl ); + else + { + //activate first table which is not hiding + tbl = doc()->map()->findSheet( doc()->map()->visibleSheets().first()); + if ( !tbl ) + { + tbl = doc()->map()->firstSheet(); + if ( tbl ) + { + tbl->setHidden( false ); + TQString tabName = tbl->sheetName(); + d->tabBar->addTab( tabName ); + } + } + setActiveSheet( tbl ); + } + + refreshView(); + + // Set the initial X and Y offsets for the view (Native format loading) + if ( !doc()->loadingInfo() ) + { + double offsetX = doc()->map()->initialXOffset(); + double offsetY = doc()->map()->initialYOffset(); + // Set the initial position for the marker as stored in the XML file, + // (1,1) otherwise + int col = doc()->map()->initialMarkerColumn(); + if ( col <= 0 ) + col = 1; + int row = doc()->map()->initialMarkerRow(); + if ( row <= 0 ) + row = 1; + d->canvas->setXOffset( offsetX ); + d->canvas->setYOffset( offsetY ); + d->horzScrollBar->setValue( (int)offsetX ); + d->vertScrollBar->setValue( (int)offsetY ); + d->selection->initialize( TQPoint(col, row) ); + } + + updateBorderButton(); + updateShowSheetMenu(); + + d->actions->autoFormat->setEnabled(false); + d->actions->sort->setEnabled(false); + d->actions->mergeCell->setEnabled(false); + d->actions->mergeCellHorizontal->setEnabled(false); + d->actions->mergeCellVertical->setEnabled(false); + d->actions->createStyle->setEnabled(false); + + d->actions->fillUp->setEnabled( false ); + d->actions->fillRight->setEnabled( false ); + d->actions->fillDown->setEnabled( false ); + d->actions->fillLeft->setEnabled( false ); + + // make paint effective: + doc()->decreaseNumOperation(); + + TQRect vr( activeSheet()->visibleRect( d->canvas ) ); + + doc()->emitBeginOperation( false ); + activeSheet()->setRegionPaintDirty( vr ); + doc()->emitEndOperation( vr ); + + if ( koDocument()->isReadWrite() ) + initConfig(); + + d->adjustActions( !d->activeSheet->isProtected() ); + d->adjustWorkbookActions( !doc()->map()->isProtected() ); + + // finish the "View Loading" process + d->loading = false; + doc()->deleteLoadingInfo(); +} + + +void View::updateEditWidgetOnPress() +{ + if (!d->activeSheet) + return; + + int column = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + Cell* cell = d->activeSheet->cellAt( column, row ); + if ( !cell ) + { + d->editWidget->setText( "" ); + return; + } + if ( d->activeSheet->isProtected() && cell->format()->isHideFormula( column, row ) ) + d->editWidget->setText( cell->strOutText() ); + else if ( d->activeSheet->isProtected() && cell->format()->isHideAll( column, row ) ) + d->editWidget->setText( "" ); + else + d->editWidget->setText( cell->text() ); + + d->updateButton(cell, column, row); + d->adjustActions( d->activeSheet, cell ); +} + +void View::updateEditWidget() +{ + if (!d->activeSheet) + return; + + int column = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + Cell * cell = d->activeSheet->cellAt( column, row ); + bool active = activeSheet()->getShowFormula() + && !( d->activeSheet->isProtected() && cell && cell->format()->isHideFormula( column, row ) ); + + if ( d->activeSheet && !d->activeSheet->isProtected() ) + { + d->actions->alignLeft->setEnabled(!active); + d->actions->alignCenter->setEnabled(!active); + d->actions->alignRight->setEnabled(!active); + } + + if ( !cell ) + { + d->editWidget->setText( "" ); + if ( d->activeSheet->isProtected() ) + d->editWidget->setEnabled( false ); + else + d->editWidget->setEnabled( true ); + return; + } + + if ( d->activeSheet->isProtected() && cell->format()->isHideFormula( column, row ) ) + d->editWidget->setText( cell->strOutText() ); + else if ( d->activeSheet->isProtected() && cell->format()->isHideAll( column, row ) ) + d->editWidget->setText( "" ); + else + d->editWidget->setText( cell->text() ); + + if ( d->activeSheet->isProtected() && !cell->format()->notProtected( column, row ) ) + d->editWidget->setEnabled( false ); + else + d->editWidget->setEnabled( true ); + + if ( d->canvas->editor() ) + { + d->canvas->editor()->setEditorFont(cell->format()->textFont(column, row), true); + d->canvas->editor()->setFocus(); + } + d->updateButton(cell, column, row); + d->adjustActions( d->activeSheet, cell ); +} + +void View::activateFormulaEditor() +{ +} + +void View::objectSelectedChanged() +{ + if ( d->canvas->isObjectSelected() ) + d->actions->actionExtraProperties->setEnabled( true ); + else + d->actions->actionExtraProperties->setEnabled( false ); +} + +void View::updateReadWrite( bool readwrite ) +{ + // d->cancelButton->setEnabled( readwrite ); + // d->okButton->setEnabled( readwrite ); + d->editWidget->setEnabled( readwrite ); + + TQValueList<TDEAction*> actions = actionCollection()->actions(); + TQValueList<TDEAction*>::ConstIterator aIt = actions.begin(); + TQValueList<TDEAction*>::ConstIterator aEnd = actions.end(); + for (; aIt != aEnd; ++aIt ) + (*aIt)->setEnabled( readwrite ); + +// d->actions->transform->setEnabled( false ); + if ( !doc() || !doc()->map() || doc()->map()->isProtected() ) + { + d->actions->showSheet->setEnabled( false ); + d->actions->hideSheet->setEnabled( false ); + } + else + { + d->actions->showSheet->setEnabled( true ); + d->actions->hideSheet->setEnabled( true ); + } + d->actions->gotoCell->setEnabled( true ); + d->actions->viewZoom->setEnabled( true ); + d->actions->showPageBorders->setEnabled( true ); + d->actions->find->setEnabled( true); + d->actions->replace->setEnabled( readwrite ); + if ( !doc()->isReadWrite()) + d->actions->copy->setEnabled( true ); + // d->actions->newView->setEnabled( true ); + //doc()->KXMLGUIClient::action( "newView" )->setEnabled( true ); // obsolete (Werner) +} + +void View::createTemplate() +{ + int width = 60; + int height = 60; + TQPixmap pix = doc()->generatePreview(TQSize(width, height)); + + KTempFile tempFile( TQString(), ".kst" ); + //Check that creation of temp file was successful + if (tempFile.status() != 0) + { + tqWarning("Creation of temprary file to store template failed."); + return; + } + + tempFile.setAutoDelete(true); + + doc()->saveNativeFormat( tempFile.name() ); + + KoTemplateCreateDia::createTemplate( "kspread_template", Factory::global(), + tempFile.name(), pix, this ); + + Factory::global()->dirs()->addResourceType("kspread_template", + TDEStandardDirs::kde_default( "data" ) + + "kspread/templates/"); +} + +void View::sheetFormat() +{ + FormatDialog dlg( this ); + dlg.exec(); +} + +void View::autoSum() +{ + if (!activeSheet()) + return; + + // ######## Torben: Make sure that this can not be called + // when canvas has a running editor + if ( d->canvas->editor() ) + return; + + //Get the selected range and remove the current cell from it (as that is + //where the result of the autosum will be stored - perhaps change + //this behaviour??) + Range rg; + //rg.sheet=activeSheet(); + TQRect sel = d->selection->selection(false); + + if (sel.height() > 1) + { + if (d->selection->marker().y()==sel.top()) + sel.setTop(sel.top()+1); + if (d->selection->marker().y()==sel.bottom()) + sel.setBottom(sel.bottom()-1); + } + else + { + if (sel.width() > 1) + { + if (d->selection->marker().x()==sel.left()) + sel.setLeft(sel.left()+1); + + if (d->selection->marker().x()==sel.right()) + sel.setRight(sel.right()-1); + } + else + { + sel=TQRect(); + + // only 1 cell selected + // try to automagically find cells the user wants to sum up + + int start = -1, end = -1; + + if ( (d->selection->marker().y() > 1) && activeSheet()->cellAt(d->selection->marker().x(), d->selection->marker().y()-1)->value().isNumber() ) + { + // check cells above the current one + start = end = d->selection->marker().y()-1; + for (start--; (start > 0) && activeSheet()->cellAt(d->selection->marker().x(), start)->value().isNumber(); start--) ; + + Point startPoint, endPoint; + startPoint.setRow(start+1); + startPoint.setColumn(d->selection->marker().x()); + endPoint.setRow(end); + endPoint.setColumn(d->selection->marker().x()); + + TQString str = Range(startPoint, endPoint).toString(); + + d->canvas->createEditor( Canvas::CellEditor , true , true ); + d->canvas->editor()->setText("=SUM(" + str + ")"); + d->canvas->editor()->setCursorPosition(5 + str.length()); + return; + } + else if ( (d->selection->marker().x() > 1) && activeSheet()->cellAt(d->selection->marker().x()-1, d->selection->marker().y())->value().isNumber() ) + { + // check cells to the left of the current one + start = end = d->selection->marker().x()-1; + for (start--; (start > 0) && activeSheet()->cellAt(start, d->selection->marker().y())->value().isNumber(); start--) ; + + Point startPoint, endPoint; + startPoint.setColumn(start+1); + startPoint.setRow(d->selection->marker().y()); + endPoint.setColumn(end); + endPoint.setRow(d->selection->marker().y()); + + TQString str = Range(startPoint, endPoint).toString(); + + d->canvas->createEditor( Canvas::CellEditor , true , true ); + d->canvas->editor()->setText("=SUM(" + str + ")"); + d->canvas->editor()->setCursorPosition(5 + str.length()); + return; + } + } + } + + if ( (sel.width() > 1) && (sel.height() > 1) ) + sel=TQRect(); + + rg.setRange(sel); + + d->canvas->createEditor( Canvas::CellEditor , true , true ); + + + if ( (rg.range().isValid() ) && (!rg.range().isEmpty()) ) + { + d->canvas->editor()->setText( "=SUM("+rg.toString()+")" ); + d->canvas->deleteEditor(true); + } + else + { + d->canvas->startChoose(); + d->canvas->editor()->setText( "=SUM()" ); + d->canvas->editor()->setCursorPosition( 5 ); + } +} + +/* +void View::oszilloscope() +{ + TQDialog* dlg = new OsziDlg( this ); + dlg->show(); +} +*/ + +void View::changeTextColor() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionTextColor( selectionInfo(), d->actions->textColor->color() ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::setSelectionTextColor(const TQColor &txtColor) +{ + if (d->activeSheet != 0L) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionTextColor( selectionInfo(), txtColor ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::changeBackgroundColor() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionbgColor( selectionInfo(), d->actions->bgColor->color() ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::setSelectionBackgroundColor(const TQColor &bgColor) +{ + if (d->activeSheet != 0L) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionbgColor( selectionInfo(), bgColor ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::changeBorderColor() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionBorderColor( selectionInfo(), d->actions->borderColor->color() ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::setSelectionBorderColor(const TQColor &bdColor) +{ + if (d->activeSheet != 0L) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionBorderColor( selectionInfo(), bdColor ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::helpUsing() +{ + kapp->invokeHelp( ); +} + +void View::enableUndo( bool _b ) +{ + TDEAction* action = actionCollection()->action( "office_undo" ); + if( action ) action->setEnabled( _b ); +} + +void View::enableRedo( bool _b ) +{ + TDEAction* action = actionCollection()->action( "office_redo" ); + if( action ) action->setEnabled( _b ); +} + +void View::enableInsertColumn( bool _b ) +{ + if ( d->activeSheet && !d->activeSheet->isProtected() ) + d->actions->insertColumn->setEnabled( _b ); +} + +void View::enableInsertRow( bool _b ) +{ + if ( d->activeSheet && !d->activeSheet->isProtected() ) + d->actions->insertRow->setEnabled( _b ); +} + +void View::deleteColumn() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + + TQRect r( d->selection->selection() ); + + d->activeSheet->removeColumn( r.left(), ( r.right()-r.left() ) ); + + updateEditWidget(); + // Stefan: update the selection after deleting (a) column(s) + d->selection->update(); + + TQRect vr( d->activeSheet->visibleRect( d->canvas ) ); + vr.setLeft( r.left() ); + + doc()->emitEndOperation( vr ); +} + +void View::deleteRow() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + TQRect r( d->selection->selection() ); + d->activeSheet->removeRow( r.top(),(r.bottom()-r.top()) ); + + updateEditWidget(); + // Stefan: update the selection after deleting (a) column(s) + d->selection->update(); + + TQRect vr( d->activeSheet->visibleRect( d->canvas ) ); + vr.setTop( r.top() ); + + doc()->emitEndOperation( vr ); +} + +void View::insertColumn() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + TQRect r( d->selection->selection() ); + d->activeSheet->insertColumn( r.left(), ( r.right()-r.left() ) ); + + updateEditWidget(); + + TQRect vr( d->activeSheet->visibleRect( d->canvas ) ); + vr.setLeft( r.left() - 1 ); + + doc()->emitEndOperation( vr ); +} + +void View::hideColumn() +{ + if ( !d->activeSheet ) + return; + + if ( d->selection->isRowSelected() ) + { + KMessageBox::error( this, i18n( "Area is too large." ) ); + return; + } + + d->activeSheet->hideColumn(*selectionInfo()); +} + +void View::showColumn() +{ + if ( !d->activeSheet ) + return; + + ShowColRow dlg( this, "showCol", ShowColRow::Column ); + dlg.exec(); +} + +void View::showSelColumns() +{ + if ( !d->activeSheet ) + return; + + d->activeSheet->showColumn(*selectionInfo()); +} + +void View::insertRow() +{ + if ( !d->activeSheet ) + return; + doc()->emitBeginOperation( false ); + TQRect r( d->selection->selection() ); + d->activeSheet->insertRow( r.top(), ( r.bottom() - r.top() ) ); + + updateEditWidget(); + TQRect vr( d->activeSheet->visibleRect( d->canvas ) ); + vr.setTop( r.top() - 1 ); + + doc()->emitEndOperation( vr ); +} + +void View::hideRow() +{ + if ( !d->activeSheet ) + return; + + if ( d->selection->isColumnSelected() ) + { + KMessageBox::error( this, i18n( "Area is too large." ) ); + return; + } + + d->activeSheet->hideRow(*selectionInfo()); +} + +void View::showRow() +{ + if ( !d->activeSheet ) + return; + + ShowColRow dlg( this, "showRow", ShowColRow::Row ); + dlg.exec(); +} + +void View::showSelRows() +{ + if ( !d->activeSheet ) + return; + + d->activeSheet->showRow(*selectionInfo()); +} + +void View::fontSelected( const TQString & _font ) +{ + if ( d->toolbarLock ) + return; + + doc()->emitBeginOperation(false); + if ( d->activeSheet != 0L ) + d->activeSheet->setSelectionFont( d->selection, _font.latin1() ); + + // Dont leave the focus in the toolbars combo box ... + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( d->selection->marker() ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( cell->column(), cell->row() ), true ); + d->canvas->editor()->setFocus(); + } + else + d->canvas->setFocus(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::decreaseFontSize() +{ + setSelectionFontSize( -1 ); +} + +void View::increaseFontSize() +{ + setSelectionFontSize( 1 ); +} + +void View::setSelectionFontSize( int size ) +{ + if ( d->activeSheet != NULL ) + { + d->activeSheet->setSelectionSize( selectionInfo(), size ); + } +} + +void View::lower() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + + d->activeSheet->setSelectionUpperLower( selectionInfo(), -1 ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::upper() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + + d->activeSheet->setSelectionUpperLower( selectionInfo(), 1 ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::firstLetterUpper() +{ + if ( !d->activeSheet ) + return; + doc()->emitBeginOperation( false ); + d->activeSheet->setSelectionfirstLetterUpper( selectionInfo() ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::verticalText(bool b) +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->setSelectionVerticalText( selectionInfo(), b ); + d->activeSheet->adjustArea(*selectionInfo()); + updateEditWidget(); // TODO Stefan: nescessary? + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::insertSpecialChar() +{ + TQString f( d->actions->selectFont->font() ); + TQChar c = ' '; + + if ( d->specialCharDlg == 0 ) + { + d->specialCharDlg = new KoCharSelectDia( this, "insert special char", f, c, false ); + connect( d->specialCharDlg, TQT_SIGNAL( insertChar( TQChar, const TQString & ) ), + this, TQT_SLOT( slotSpecialChar( TQChar, const TQString & ) ) ); + connect( d->specialCharDlg, TQT_SIGNAL( finished() ), + this, TQT_SLOT( slotSpecialCharDlgClosed() ) ); + } + d->specialCharDlg->show(); +} + +void View::slotSpecialCharDlgClosed() +{ + if ( d->specialCharDlg ) + { + disconnect( d->specialCharDlg, TQT_SIGNAL(insertChar(TQChar,const TQString &)), + this, TQT_SLOT(slotSpecialChar(TQChar,const TQString &))); + disconnect( d->specialCharDlg, TQT_SIGNAL( finished() ), + this, TQT_SLOT( slotSpecialCharDlgClosed() ) ); + d->specialCharDlg->deleteLater(); + d->specialCharDlg = 0L; + } +} + +void View::slotSpecialChar( TQChar c, const TQString & _font ) +{ + if ( d->activeSheet ) + { + TQPoint marker( d->selection->marker() ); + Cell * cell = d->activeSheet->nonDefaultCell( marker ); + if ( cell->format()->textFont( marker.x(), marker.y() ).family() != _font ) + { + cell->format()->setTextFontFamily( _font ); + } + EditWidget * edit = d->editWidget; + TQKeyEvent ev( TQEvent::KeyPress, 0, 0, 0, TQString( c ) ); + TQApplication::sendEvent( edit, &ev ); + } +} + +void View::insertMathExpr() +{ + if ( d->activeSheet == 0L ) + return; + + FormulaDialog * dlg = new FormulaDialog( this, "Function" ); + dlg->show(); + + /* TODO - because I search on 'TODO's :-) */ + // #### Is the dialog deleted when it's closed ? (David) + // Torben thinks that not. +} + +void View::formulaSelection( const TQString &_math ) +{ + if ( d->activeSheet == 0 ) + return; + + if ( _math == i18n("Others...") ) + { + insertMathExpr(); + return; + } + + FormulaDialog *dlg = new FormulaDialog( this, "Formula Editor", _math ); + dlg->exec(); +} + +void View::fontSizeSelected( int _size ) +{ + if ( d->toolbarLock ) + return; + + doc()->emitBeginOperation( false ); + + if ( d->activeSheet != 0L ) + d->activeSheet->setSelectionFont( selectionInfo(), 0L, _size ); + + // Dont leave the focus in the toolbars combo box ... + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( d->selection->marker() ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( d->canvas->markerColumn(), + d->canvas->markerRow() ), true ); + d->canvas->editor()->setFocus(); + } + else + d->canvas->setFocus(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::bold( bool b ) +{ + if ( d->toolbarLock ) + return; + if ( d->activeSheet == 0 ) + return; + + doc()->emitBeginOperation( false ); + + int col = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + d->activeSheet->setSelectionFont( selectionInfo(), 0L, -1, b ); + + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( col, row ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( col, row ), true ); + } + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::underline( bool b ) +{ + if ( d->toolbarLock ) + return; + if ( d->activeSheet == 0 ) + return; + + doc()->emitBeginOperation( false ); + + int col = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + d->activeSheet->setSelectionFont( selectionInfo(), 0L, -1, -1, -1 ,b ); + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( col, row ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( col, row ), true ); + } + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::strikeOut( bool b ) +{ + if ( d->toolbarLock ) + return; + if ( d->activeSheet == 0 ) + return; + + doc()->emitBeginOperation( false ); + + int col = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + d->activeSheet->setSelectionFont( selectionInfo(), 0L, -1, -1, -1 ,-1, b ); + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( col, row ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( col, row ), true ); + } + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + + +void View::italic( bool b ) +{ + if ( d->toolbarLock ) + return; + if ( d->activeSheet == 0 ) + return; + + doc()->emitBeginOperation( false ); + + int col = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + d->activeSheet->setSelectionFont( selectionInfo(), 0L, -1, -1, b ); + if ( d->canvas->editor() ) + { + Cell * cell = d->activeSheet->cellAt( col, row ); + d->canvas->editor()->setEditorFont( cell->format()->textFont( col, row ), true ); + } + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::sortInc() +{ + if (!activeSheet()) + return; + + TQRect range = d->selection->selection(); + if ( d->selection->isSingular() ) + { + KMessageBox::error( this, i18n( "You must select multiple cells." ) ); + return; + } + + doc()->emitBeginOperation( false ); + + // Entire row(s) selected ? Or just one row ? + if ( d->selection->isRowSelected() || range.top() == range.bottom() ) + activeSheet()->sortByRow( range, range.top(), Sheet::Increase ); + else + activeSheet()->sortByColumn( range, range.left(), Sheet::Increase ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::sortDec() +{ + TQRect range = d->selection->selection(); + if ( d->selection->isSingular() ) + { + KMessageBox::error( this, i18n( "You must select multiple cells." ) ); + return; + } + + doc()->emitBeginOperation( false ); + + // Entire row(s) selected ? Or just one row ? + if ( d->selection->isRowSelected() || range.top() == range.bottom() ) + activeSheet()->sortByRow( range, range.top(), Sheet::Decrease ); + else + activeSheet()->sortByColumn( range, range.left(), Sheet::Decrease ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + + +void View::borderBottom() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + + d->activeSheet->borderBottom( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionBottomBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderBottom( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderRight() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + d->activeSheet->borderLeft( d->selection, d->actions->borderColor->color() ); + else + d->activeSheet->borderRight( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionRightBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + d->activeSheet->borderLeft( selectionInfo(), color ); + else + d->activeSheet->borderRight( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderLeft() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + d->activeSheet->borderRight( d->selection, d->actions->borderColor->color() ); + else + d->activeSheet->borderLeft( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionLeftBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + d->activeSheet->borderRight( selectionInfo(), color ); + else + d->activeSheet->borderLeft( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderTop() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderTop( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionTopBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderTop( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderOutline() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderOutline( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionOutlineBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderOutline( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderAll() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderAll( d->selection, d->actions->borderColor->color() ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::setSelectionAllBorderColor( const TQColor & color ) +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->borderAll( selectionInfo(), color ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::borderRemove() +{ + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation(false); + d->activeSheet->borderRemove( d->selection ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::addSheet( Sheet * _t ) +{ + doc()->emitBeginOperation( false ); + + insertSheet( _t ); + + // Connect some signals + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_refreshView() ), TQT_SLOT( slotRefreshView() ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateView( Sheet* ) ), TQT_SLOT( slotUpdateView( Sheet* ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t->print(), TQT_SIGNAL( sig_updateView( Sheet* ) ), TQT_SLOT( slotUpdateView( Sheet* ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateView( Sheet *, const Region& ) ), + TQT_SLOT( slotUpdateView( Sheet*, const Region& ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateView( EmbeddedObject* )), TQT_SLOT( slotUpdateView( EmbeddedObject* ) ) ); + + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateHBorder( Sheet * ) ), + TQT_SLOT( slotUpdateHBorder( Sheet * ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateVBorder( Sheet * ) ), + TQT_SLOT( slotUpdateVBorder( Sheet * ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_nameChanged( Sheet*, const TQString& ) ), + this, TQT_SLOT( slotSheetRenamed( Sheet*, const TQString& ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_SheetHidden( Sheet* ) ), + this, TQT_SLOT( slotSheetHidden( Sheet* ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_SheetShown( Sheet* ) ), + this, TQT_SLOT( slotSheetShown( Sheet* ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_SheetRemoved( Sheet* ) ), + this, TQT_SLOT( slotSheetRemoved( Sheet* ) ) ); + // ########### Why do these signals not send a pointer to the sheet? + // This will lead to bugs. + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_updateChildGeometry( EmbeddedKOfficeObject* ) ), + TQT_SLOT( slotUpdateChildGeometry( EmbeddedKOfficeObject* ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_maxColumn( int ) ), d->canvas, TQT_SLOT( slotMaxColumn( int ) ) ); + TQT_BASE_OBJECT_NAME::connect( _t, TQT_SIGNAL( sig_maxRow( int ) ), d->canvas, TQT_SLOT( slotMaxRow( int ) ) ); + + if ( !d->loading ) + updateBorderButton(); + + if ( !d->activeSheet ) + { + doc()->emitEndOperation(); + return; + } + doc()->emitEndOperation( *selectionInfo() ); +} + +void View::slotSheetRemoved( Sheet *_t ) +{ + doc()->emitBeginOperation( false ); + + TQString m_sheetName=_t->sheetName(); + d->tabBar->removeTab( _t->sheetName() ); + if (doc()->map()->findSheet( doc()->map()->visibleSheets().first())) + setActiveSheet( doc()->map()->findSheet( doc()->map()->visibleSheets().first() )); + else + d->activeSheet = 0L; + + TQValueList<Reference>::Iterator it; + TQValueList<Reference> area=doc()->listArea(); + for ( it = area.begin(); it != area.end(); ++it ) + { + //remove Area Name when sheet target is removed + if ( (*it).sheet_name == m_sheetName ) + { + doc()->removeArea( (*it).ref_name ); + //now area name is used in formula + //so you must recalc sheets when remove areaname + Sheet * tbl; + + for ( tbl = doc()->map()->firstSheet(); tbl != 0L; tbl = doc()->map()->nextSheet() ) + { + tbl->refreshRemoveAreaName((*it).ref_name); + } + } + } + + doc()->emitEndOperation( *selectionInfo() ); +} + +void View::removeAllSheets() +{ + doc()->emitBeginOperation(false); + d->tabBar->clear(); + + setActiveSheet( 0L ); + + doc()->emitEndOperation(); +} + +void View::setActiveSheet( Sheet * _t, bool updateSheet ) +{ + if ( _t == d->activeSheet ) + return; + + doc()->emitBeginOperation(false); + + saveCurrentSheetSelection(); + + Sheet * oldSheet = d->activeSheet; + + d->activeSheet = _t; + + if ( d->activeSheet == 0L ) + { + doc()->emitEndOperation(); + return; + } + + if ( oldSheet && oldSheet->layoutDirection()==Sheet::RightToLeft != d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + refreshView(); + + doc()->setDisplaySheet( d->activeSheet ); + if ( updateSheet ) + { + d->tabBar->setActiveTab( _t->sheetName() ); + d->vBorderWidget->repaint(); + d->hBorderWidget->repaint(); + d->activeSheet->setRegionPaintDirty(TQRect(TQPoint(0,0), TQPoint(KS_colMax, KS_rowMax))); + d->canvas->slotMaxColumn( d->activeSheet->maxColumn() ); + d->canvas->slotMaxRow( d->activeSheet->maxRow() ); + } + + d->actions->showPageBorders->setChecked( d->activeSheet->isShowPageBorders() ); + d->actions->protectSheet->setChecked( d->activeSheet->isProtected() ); + d->actions->protectDoc->setChecked( doc()->map()->isProtected() ); + d->adjustActions( !d->activeSheet->isProtected() ); + d->adjustWorkbookActions( !doc()->map()->isProtected() ); + + /* see if there was a previous selection on this other sheet */ + TQMapIterator<Sheet*, TQPoint> it = d->savedAnchors.find(d->activeSheet); + TQMapIterator<Sheet*, TQPoint> it2 = d->savedMarkers.find(d->activeSheet); + TQMapIterator<Sheet*, KoPoint> it3 = d->savedOffsets.find(d->activeSheet); + + // TODO Stefan: store the save markers/anchors in the Selection? + TQPoint newAnchor = (it == d->savedAnchors.end()) ? TQPoint(1,1) : *it; + TQPoint newMarker = (it2 == d->savedMarkers.end()) ? TQPoint(1,1) : *it2; + + d->selection->clear(); + d->selection->setSheet( d->activeSheet ); + d->selection->initialize(TQRect(newMarker, newAnchor)); + + d->canvas->scrollToCell(newMarker); + if (it3 != d->savedOffsets.end()) + { + d->canvas->setXOffset((*it3).x()); + d->canvas->setYOffset((*it3).y()); + d->horzScrollBar->setValue((int)(*it3).x()); + d->vertScrollBar->setValue((int)(*it3).y()); + } + calcStatusBarOp(); + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::slotSheetRenamed( Sheet* sheet, const TQString& old_name ) +{ + doc()->emitBeginOperation( false ); + d->tabBar->renameTab( old_name, sheet->sheetName() ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::slotSheetHidden( Sheet* ) +{ + doc()->emitBeginOperation(false); + updateShowSheetMenu(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::slotSheetShown( Sheet* ) +{ + doc()->emitBeginOperation(false); + d->tabBar->setTabs( doc()->map()->visibleSheets() ); + updateShowSheetMenu(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::changeSheet( const TQString& _name ) +{ + if ( activeSheet()->sheetName() == _name ) + return; + + Sheet *t = doc()->map()->findSheet( _name ); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " << _name << endl; + return; + } + doc()->emitBeginOperation(false); + d->canvas->closeEditor(); // for selection mode + setActiveSheet( t, false /* False: Endless loop because of setActiveTab() => do the visual area update manually*/); + + d->canvas->updateEditor(); // for choose mode + updateEditWidget(); + //refresh toggle button + updateBorderButton(); + + //update visible area + d->vBorderWidget->repaint(); + d->hBorderWidget->repaint(); + d->canvas->slotMaxColumn( d->activeSheet->maxColumn() ); + d->canvas->slotMaxRow( d->activeSheet->maxRow() ); + t->setRegionPaintDirty( t->visibleRect( d->canvas ) ); + doc()->emitEndOperation(); +} + +void View::moveSheet( unsigned sheet, unsigned target ) +{ + if( doc()->map()->isProtected() ) return; + + TQStringList vs = doc()->map()->visibleSheets(); + + if( target >= vs.count() ) + doc()->map()->moveSheet( vs[ sheet ], vs[ vs.count()-1 ], false ); + else + doc()->map()->moveSheet( vs[ sheet ], vs[ target ], true ); + + d->tabBar->moveTab( sheet, target ); +} + +void View::sheetProperties() +{ + // sanity check, shouldn't happen + if( doc()->map()->isProtected() ) return; + if( d->activeSheet->isProtected() ) return; + + bool directionChanged = false; + + SheetPropertiesDialog* dlg = new SheetPropertiesDialog( this ); + dlg->setLayoutDirection( d->activeSheet->layoutDirection() ); + dlg->setAutoCalc( d->activeSheet->getAutoCalc() ); + dlg->setShowGrid( d->activeSheet->getShowGrid() ); + dlg->setShowPageBorders( d->activeSheet->isShowPageBorders() ); + dlg->setShowFormula( d->activeSheet->getShowFormula() ); + dlg->setHideZero( d->activeSheet->getHideZero() ); + dlg->setShowFormulaIndicator( d->activeSheet->getShowFormulaIndicator() ); + dlg->setShowCommentIndicator( d->activeSheet->getShowCommentIndicator() ); + dlg->setColumnAsNumber( d->activeSheet->getShowColumnNumber() ); + dlg->setLcMode( d->activeSheet->getLcMode() ); + dlg->setCapitalizeFirstLetter( d->activeSheet->getFirstLetterUpper() ); + + if( dlg->exec() ) + { + SheetPropertiesCommand* command = new SheetPropertiesCommand( doc(), d->activeSheet ); + + if ( d->activeSheet->layoutDirection() != dlg->layoutDirection() ) + directionChanged = true; + + command->setLayoutDirection( dlg->layoutDirection() ); + command->setAutoCalc( dlg->autoCalc() ); + command->setShowGrid( dlg->showGrid() ); + command->setShowPageBorders( dlg->showPageBorders() ); + command->setShowFormula( dlg->showFormula() ); + command->setHideZero( dlg->hideZero() ); + command->setShowFormulaIndicator( dlg->showFormulaIndicator() ); + command->setShowCommentIndicator( dlg->showCommentIndicator() ); + command->setColumnAsNumber( dlg->columnAsNumber() ); + command->setLcMode( dlg->lcMode() ); + command->setCapitalizeFirstLetter( dlg->capitalizeFirstLetter() ); + doc()->addCommand( command ); + command->execute(); + } + + delete dlg; + + if ( directionChanged ) + { + // the scrollbar and hborder remain reversed otherwise + d->horzScrollBar->setValue( d->horzScrollBar->maxValue() - + d->horzScrollBar->value() ); + d->hBorderWidget->update(); + } +} + +void View::insertSheet() +{ + if ( doc()->map()->isProtected() ) + { + KMessageBox::error( 0, i18n ( "You cannot change a protected sheet." ) ); + return; + } + + doc()->emitBeginOperation( false ); + d->canvas->closeEditor(); + Sheet * t = doc()->map()->createSheet(); + KCommand* command = new AddSheetCommand( t ); + doc()->addCommand( command ); + updateEditWidget(); + setActiveSheet( t ); + + if ( doc()->map()->visibleSheets().count() > 1 ) + { + d->actions->removeSheet->setEnabled( true ); + d->actions->hideSheet->setEnabled( true ); + } + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::hideSheet() +{ + if ( !d->activeSheet ) + return; + + if ( doc()->map()->visibleSheets().count() == 1) + { + KMessageBox::error( this, i18n("You cannot hide the last visible sheet.") ); + return; + } + + TQStringList vs = doc()->map()->visibleSheets(); + int i = vs.findIndex( d->activeSheet->tableName() ) - 1; + if( i < 0 ) i = 1; + TQString sn = vs[i]; + + doc()->emitBeginOperation(false); + + KCommand* command = new HideSheetCommand( activeSheet() ); + doc()->addCommand( command ); + command->execute(); + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + + d->tabBar->removeTab( d->activeSheet->sheetName() ); + d->tabBar->setActiveTab( sn ); +} + +void View::showSheet() +{ + if ( !d->activeSheet ) + return; + + ShowDialog dlg( this, "Sheet show"); + dlg.exec(); +} + +void View::copySelection() +{ + if ( !d->activeSheet ) + return; + + if ( canvasWidget()->isObjectSelected() ) + { + canvasWidget()->copyOasisObjects(); + return; + } + if ( !d->canvas->editor() ) + { + d->activeSheet->copySelection( selectionInfo() ); + + updateEditWidget(); + } + else + d->canvas->editor()->copy(); +} + +void View::copyAsText() +{ + if ( !d->activeSheet ) + return; + d->activeSheet->copyAsText( selectionInfo() ); +} + + +void View::cutSelection() +{ + if ( !d->activeSheet ) + return; + //don't used this function when we edit a cell. + doc()->emitBeginOperation(false); + + if ( canvasWidget()->isObjectSelected() ) + { + canvasWidget()->copyOasisObjects(); + markSelectionAsDirty(); + doc()->emitEndOperation(); + + KMacroCommand * macroCommand = 0L; + TQPtrListIterator<EmbeddedObject> it( doc()->embeddedObjects() ); + for ( ; it.current() ; ++it ) + { + if ( it.current()->sheet() == canvasWidget()->activeSheet() && it.current()->isSelected() ) + { + if( !macroCommand ) + macroCommand = new KMacroCommand( i18n( "Cut Objects" ) ); + RemoveObjectCommand *cmd = new RemoveObjectCommand( it.current(), true ); + macroCommand->addCommand( cmd ); + } + } + if ( macroCommand ) + { + doc()->addCommand( macroCommand ); + canvasWidget()->setMouseSelectedObject( false ); + macroCommand->execute(); + } + + return; + } + if ( !d->canvas->editor()) + { + d->activeSheet->cutSelection( selectionInfo() ); + calcStatusBarOp(); + updateEditWidget(); + } +else + d->canvas->editor()->cut(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::paste() +{ + if ( !d->activeSheet ) + return; + + if (!koDocument()->isReadWrite()) // don't paste into a read only document + return; + + TQMimeSource *data = TQApplication::clipboard()->data( TQClipboard::Clipboard ); + for ( int i=0; data->format(i) != 0; i++ ) + kdDebug() << "format:" << data->format(i) << endl; + + if ( data->provides( KoStoreDrag::mimeType("application/vnd.oasis.opendocument.spreadsheet" ) )) + { + canvasWidget()->deselectAllObjects(); + TQCString returnedTypeMime = "application/vnd.oasis.opendocument.spreadsheet"; + const TQByteArray arr = data->encodedData( returnedTypeMime ); + if( arr.isEmpty() ) + return; + TQBuffer buffer( arr ); + KoStore * store = KoStore::createStore( TQT_TQIODEVICE(&buffer), KoStore::Read ); + + KoOasisStore oasisStore( store ); + TQDomDocument doc; + TQString errorMessage; + bool ok = oasisStore.loadAndParse( "content.xml", doc, errorMessage ); + if ( !ok ) { + kdError(32001) << "Error parsing content.xml: " << errorMessage << endl; + return; + } + + KoOasisStyles oasisStyles; + TQDomDocument stylesDoc; + (void)oasisStore.loadAndParse( "styles.xml", stylesDoc, errorMessage ); + // Load styles from style.xml + oasisStyles.createStyleMap( stylesDoc, true ); + // Also load styles from content.xml + oasisStyles.createStyleMap( doc, false ); + + // from KSpreadDoc::loadOasis: + TQDomElement content = doc.documentElement(); + TQDomElement realBody ( KoDom::namedItemNS( content, KoXmlNS::office, "body" ) ); + if ( realBody.isNull() ) + { + kdDebug() << "Invalid OASIS OpenDocument file. No office:body tag found." << endl; + return; + } + TQDomElement body = KoDom::namedItemNS( realBody, KoXmlNS::office, "spreadsheet" ); + + if ( body.isNull() ) + { + kdError(32001) << "No office:spreadsheet found!" << endl; + TQDomElement childElem; + TQString localName; + forEachElement( childElem, realBody ) { + localName = childElem.localName(); + } + return; + } + + KoOasisLoadingContext context( d->doc, oasisStyles, store ); + Q_ASSERT( !oasisStyles.officeStyle().isNull() ); + + //load in first + d->doc->styleManager()->loadOasisStyleTemplate( oasisStyles ); + +// // TODO check versions and mimetypes etc. + d->doc->loadOasisAreaName( body ); + d->doc->loadOasisCellValidation( body ); + + // all <sheet:sheet> goes to workbook + bool result = d->doc->map()->loadOasis( body, context ); + + if (!result) + return; + } + else + { + //TODO: What if the clipboard data is available in both pixmap and OASIS format? (ie. for embedded parts) + TQPixmap clipboardPixmap = TQApplication::clipboard()->pixmap( TQClipboard::Clipboard ); + if (!clipboardPixmap.isNull()) + { + d->activeSheet->insertPicture( markerDocumentPosition() , clipboardPixmap ); + } + } + + doc()->emitBeginOperation( false ); + if ( !d->canvas->editor() ) + { + //kdDebug(36001) << "Pasting. Rect= " << d->selection->selection(false) << " bytes" << endl; + d->activeSheet->paste( d->selection->lastRange(), true, + Paste::Normal, Paste::OverWrite, + false, 0, true ); + calcStatusBarOp(); + updateEditWidget(); + } + else + { + d->canvas->editor()->paste(); + } + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::specialPaste() +{ + if ( !d->activeSheet ) + return; + + SpecialDialog dlg( this, "Special Paste" ); + if ( dlg.exec() ) + { + if ( d->activeSheet->getAutoCalc() ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->recalc(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } + calcStatusBarOp(); + updateEditWidget(); + } +} + +void View::removeComment() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionRemoveComment( selectionInfo() ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + + +void View::changeAngle() +{ + if ( !d->activeSheet ) + return; + + AngleDialog dlg( this, "Angle" , + TQPoint( d->canvas->markerColumn(), d->canvas->markerRow() )); + if ( dlg.exec() ) + { + //TODO Stefan: where is the angle operation? + d->activeSheet->adjustArea(*selectionInfo()); + } +} + +void View::setSelectionAngle( int angle ) +{ + doc()->emitBeginOperation( false ); + + if ( d->activeSheet != NULL ) + { + d->activeSheet->setSelectionAngle( selectionInfo(), angle ); + d->activeSheet->adjustArea(*selectionInfo()); + } + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::mergeCell() +{ + // sanity check + if( !d->activeSheet ) + return; + d->activeSheet->mergeCells(*selectionInfo()); +} + +void View::mergeCellHorizontal() +{ + // sanity check + if( !d->activeSheet ) + return; + d->activeSheet->mergeCells(*selectionInfo(), true); +} + +void View::mergeCellVertical() +{ + // sanity check + if( !d->activeSheet ) + return; + d->activeSheet->mergeCells(*selectionInfo(), false, true); +} + +void View::dissociateCell() +{ + // sanity check + if( !d->activeSheet ) + return; + d->activeSheet->dissociateCells(*selectionInfo()); +} + + +void View::increaseIndent() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->increaseIndent( d->selection ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::decreaseIndent() +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + int column = d->canvas->markerColumn(); + int row = d->canvas->markerRow(); + + d->activeSheet->decreaseIndent( d->selection ); + Cell * cell = d->activeSheet->cellAt( column, row ); + if ( cell ) + if ( !d->activeSheet->isProtected() ) + d->actions->decreaseIndent->setEnabled( cell->format()->getIndent( column, row ) > 0.0 ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::goalSeek() +{ + if ( d->canvas->editor() ) + { + d->canvas->deleteEditor( true ); // save changes + } + + GoalSeekDialog * dlg + = new GoalSeekDialog( this, TQPoint( d->canvas->markerColumn(), + d->canvas->markerRow() ), + "GoalSeekDialog" ); + dlg->show(); + /* dialog autodeletes itself */ +} + +void View::subtotals() +{ + if (!activeSheet()) + return; + + TQRect selection( d->selection->selection() ); + if ( ( selection.width() < 2 ) || ( selection.height() < 2 ) ) + { + KMessageBox::error( this, i18n("You must select multiple cells.") ); + return; + } + + SubtotalDialog dlg(this, selection, "SubtotalDialog" ); + if ( dlg.exec() ) + { + doc()->emitBeginOperation( false ); + + d->selection->initialize( TQRect(dlg.selection().topLeft(), dlg.selection().bottomRight()));//, dlg.sheet() ); + doc()->emitEndOperation( selection ); + } +} + +void View::multipleOperations() +{ + if ( d->canvas->editor() ) + { + d->canvas->deleteEditor( true ); // save changes + } + // MultipleOpDlg * dlg = new MultipleOpDlg( this, "MultipleOpDlg" ); + // dlg->show(); +} + +void View::textToColumns() +{ + if (!activeSheet()) + return; + + d->canvas->closeEditor(); + + TQRect area=d->selection->selection(); + + //Only use the first column + area.setRight(area.left()); + +/* if ( area.width() > 1 ) + { + //Only use the first column + + KMessageBox::error( this, i18n("You must not select an area containing more than one column.") ); + return; + }*/ + + CSVDialog dialog( this, "CSVDialog", area, CSVDialog::Column ); + if( !dialog.cancelled() ) + dialog.exec(); +} + +void View::consolidate() +{ + d->canvas->closeEditor(); + ConsolidateDialog * dlg = new ConsolidateDialog( this, "ConsolidateDialog" ); + dlg->show(); + // dlg destroys itself +} + +void View::sortList() +{ + if (!activeSheet()) return; + + ListDialog dlg( this, "List selection" ); + dlg.exec(); +} + +void View::gotoCell() +{ + if (!activeSheet()) return; + + GotoDialog dlg( this, "GotoCell" ); + dlg.exec(); +} + +void View::find() +{ + if (!activeSheet()) return; + + FindDlg dlg( this, "Find", d->findOptions, d->findStrings ); + dlg.setHasSelection( !d->selection->isSingular() ); + dlg.setHasCursor( true ); + if ( KFindDialog::Accepted != dlg.exec() ) + return; + + // Save for next time + d->findOptions = dlg.options(); + d->findStrings = dlg.findHistory(); + d->typeValue = dlg.searchType(); + d->directionValue = dlg.searchDirection(); + + // Create the KFind object + delete d->find; + delete d->replace; + d->find = new KFind( dlg.pattern(), dlg.options(), this ); + d->replace = 0L; + + d->searchInSheets.currentSheet = activeSheet(); + d->searchInSheets.firstSheet = d->searchInSheets.currentSheet; + + initFindReplace(); + findNext(); +} + +// Initialize a find or replace operation, using d->find or d->replace, +// and d->findOptions. +void View::initFindReplace() +{ + KFind* findObj = d->find ? d->find : d->replace; + Q_ASSERT( findObj ); + connect(findObj, TQT_SIGNAL( highlight( const TQString &, int, int ) ), + this, TQT_SLOT( slotHighlight( const TQString &, int, int ) ) ); + connect(findObj, TQT_SIGNAL( findNext() ), + this, TQT_SLOT( findNext() ) ); + + bool bck = d->findOptions & KFindDialog::FindBackwards; + Sheet* currentSheet = d->searchInSheets.currentSheet; + + TQRect region = ( d->findOptions & KFindDialog::SelectedText ) + ? d->selection->selection() + : TQRect( 1, 1, currentSheet->maxColumn(), currentSheet->maxRow() ); // All cells + + int colStart = !bck ? region.left() : region.right(); + int colEnd = !bck ? region.right() : region.left(); + int rowStart = !bck ? region.top() :region.bottom(); + int rowEnd = !bck ? region.bottom() : region.top(); + if ( d->findOptions & KFindDialog::FromCursor ) { + TQPoint marker( d->selection->marker() ); + colStart = marker.x(); + rowStart = marker.y(); + } + d->findLeftColumn = region.left(); + d->findRightColumn = region.right(); + d->findPos = TQPoint( colStart, rowStart ); + d->findEnd = TQPoint( colEnd, rowEnd ); + //kdDebug() << k_funcinfo << d->findPos << " to " << d->findEnd << endl; + //kdDebug() << k_funcinfo << "leftcol=" << d->findLeftColumn << " rightcol=" << d->findRightColumn << endl; +} + +void View::findNext() +{ + KFind* findObj = d->find ? d->find : d->replace; + if ( !findObj ) { + find(); + return; + } + KFind::Result res = KFind::NoMatch; + Cell* cell = findNextCell(); + bool forw = ! ( d->findOptions & KFindDialog::FindBackwards ); + while ( res == KFind::NoMatch && cell ) + { + if ( findObj->needData() ) + { + if ( d->typeValue == FindOption::Note ) + findObj->setData( cell->format()->comment( cell->column(), cell->row() ) ); + else + findObj->setData( cell->text() ); + d->findPos = TQPoint( cell->column(), cell->row() ); + //kdDebug() << "setData(cell " << d->findPos << ")" << endl; + } + + // Let KFind inspect the text fragment, and display a dialog if a match is found + if ( d->find ) + res = d->find->find(); + else + res = d->replace->replace(); + + if ( res == KFind::NoMatch ) { + // Go to next cell, skipping unwanted cells + if ( d->directionValue == FindOption::Row ) + { + if ( forw ) + ++d->findPos.rx(); + else + --d->findPos.rx(); + } + else + { + if ( forw ) + ++d->findPos.ry(); + else + --d->findPos.ry(); + } + cell = findNextCell(); + } + } + + if ( res == KFind::NoMatch ) + { + //emitUndoRedo(); + //removeHighlight(); + if ( findObj->shouldRestart() ) { + d->findOptions &= ~KFindDialog::FromCursor; + findObj->resetCounts(); + findNext(); + } + else { // done, close the 'find next' dialog + if ( d->find ) + d->find->closeFindNextDialog(); + else + d->replace->closeReplaceNextDialog(); + } + } +} + +Cell* View::nextFindValidCell( int col, int row ) +{ + Cell *cell = d->searchInSheets.currentSheet->cellAt( col, row ); + if ( cell->isDefault() || cell->isObscured() || cell->isFormula() ) + cell = 0L; + if ( d->typeValue == FindOption::Note && cell && cell->format()->comment(col, row).isEmpty()) + cell = 0L; + return cell; +} + +Cell* View::findNextCell() +{ + // getFirstCellRow / getNextCellRight would be faster at doing that, + // but it doesn't seem to be easy to combine it with 'start a column d->find.x()'... + + Sheet* sheet = d->searchInSheets.currentSheet; + Cell* cell = 0L; + bool forw = ! ( d->findOptions & KFindDialog::FindBackwards ); + int col = d->findPos.x(); + int row = d->findPos.y(); + int maxRow = sheet->maxRow(); + //kdDebug() << "findNextCell starting at " << col << "," << row << " forw=" << forw << endl; + + if ( d->directionValue == FindOption::Row ) + { + while ( !cell && row != d->findEnd.y() && (forw ? row < maxRow : row >= 0) ) + { + while ( !cell && (forw ? col <= d->findRightColumn : col >= d->findLeftColumn) ) + { + cell = nextFindValidCell( col, row ); + if ( forw ) ++col; + else --col; + } + if ( cell ) + break; + // Prepare looking in the next row + if ( forw ) { + col = d->findLeftColumn; + ++row; + } else { + col = d->findRightColumn; + --row; + } + //kdDebug() << "next row: " << col << "," << row << endl; + } + } + else + { + while ( !cell && (forw ? col <= d->findRightColumn : col >= d->findLeftColumn) ) + { + while ( !cell && row != d->findEnd.y() && (forw ? row < maxRow : row >= 0) ) + { + cell = nextFindValidCell( col, row ); + if ( forw ) ++row; + else --row; + } + if ( cell ) + break; + // Prepare looking in the next col + if ( forw ) { + row = 0; + ++col; + } else { + col = maxRow; + --col; + } + //kdDebug() << "next row: " << col << "," << row << endl; + } + } + // if ( !cell ) + // No more next cell - TODO go to next sheet (if not looking in a selection) + // (and make d->findEnd (max,max) in that case...) + //kdDebug() << k_funcinfo << " returning " << cell << endl; + return cell; +} + +void View::findPrevious() +{ + KFind* findObj = d->find ? d->find : d->replace; + if ( !findObj ) { + find(); + return; + } + //kdDebug() << "findPrevious" << endl; + int opt = d->findOptions; + bool forw = ! ( opt & KFindDialog::FindBackwards ); + if ( forw ) + d->findOptions = ( opt | KFindDialog::FindBackwards ); + else + d->findOptions = ( opt & ~KFindDialog::FindBackwards ); + + findNext(); + + d->findOptions = opt; // restore initial options +} + +void View::replace() +{ + if (!d->activeSheet) + return; + + SearchDlg dlg( this, "Replace", d->findOptions, d->findStrings, d->replaceStrings ); + dlg.setHasSelection( !d->selection->isSingular() ); + dlg.setHasCursor( true ); + if ( KReplaceDialog::Accepted != dlg.exec() ) + return; + + d->findOptions = dlg.options(); + d->findStrings = dlg.findHistory(); + d->replaceStrings = dlg.replacementHistory(); + d->typeValue = dlg.searchType(); + + delete d->find; + delete d->replace; + d->find = 0L; + // NOTE Stefan: Avoid beginning of line replacements with nothing which + // will lead to an infinite loop (Bug #125535). The reason + // for this is unclear to me, but who cares and who would + // want to do something like this, häh?! + if (dlg.pattern() == "^" && dlg.replacement().isEmpty()) + return; + d->replace = new KReplace( dlg.pattern(), dlg.replacement(), dlg.options() ); + + d->searchInSheets.currentSheet = activeSheet(); + d->searchInSheets.firstSheet = d->searchInSheets.currentSheet; + initFindReplace(); + connect( d->replace, TQT_SIGNAL( replace( const TQString &, int, int, int ) ), + this, TQT_SLOT( slotReplace( const TQString &, int, int, int ) ) ); + + if ( !doc()->undoLocked() ) + { + TQRect region( d->findPos, d->findEnd ); + //TODO create undo/redo for comment + UndoChangeAreaTextCell *undo = new UndoChangeAreaTextCell( doc(), d->searchInSheets.currentSheet, region ); + doc()->addCommand( undo ); + } + + findNext(); + +#if 0 + // Refresh the editWidget + // TODO - after a replacement only? + Cell *cell = activeSheet()->cellAt( canvasWidget()->markerColumn(), + canvasWidget()->markerRow() ); + if ( cell->text() != 0L ) + d->editWidget->setText( cell->text() ); + else + d->editWidget->setText( "" ); +#endif +} + +void View::slotHighlight( const TQString &/*text*/, int /*matchingIndex*/, int /*matchedLength*/ ) +{ + d->selection->initialize( d->findPos ); + KDialogBase *baseDialog=0L; + if ( d->find ) + baseDialog = d->find->findNextDialog(); + else + baseDialog = d->replace->replaceNextDialog(); + kdDebug()<<" baseDialog :"<<baseDialog<<endl; + TQRect globalRect( d->findPos, d->findEnd ); + globalRect.moveTopLeft( canvasWidget()->mapToGlobal( globalRect.topLeft() ) ); + KDialog::avoidArea( baseDialog, TQRect( d->findPos, d->findEnd )); +} + +void View::slotReplace( const TQString &newText, int, int, int ) +{ + // Which cell was this again? + Cell *cell = d->searchInSheets.currentSheet->cellAt( d->findPos ); + + // ...now I remember, update it! + cell->setDisplayDirtyFlag(); + if ( d->typeValue == FindOption::Value ) + cell->setCellText( newText ); + else if ( d->typeValue == FindOption::Note ) + cell->format()->setComment( newText ); + cell->clearDisplayDirtyFlag(); +} + +void View::conditional() +{ + TQRect rect( d->selection->selection() ); + + if ( util_isRowOrColumnSelected(rect)) + { + KMessageBox::error( this, i18n("Area is too large.") ); + } + else + { + ConditionalDialog dlg( this, "ConditionalDialog", rect); + dlg.exec(); + } +} + +void View::validity() +{ + TQRect rect( d->selection->selection() ); + + if (d->selection->isColumnOrRowSelected()) + { + KMessageBox::error( this, i18n("Area is too large.")); + } + else + { + DlgValidity dlg( this,"validity",rect); + dlg.exec(); + } +} + + +void View::insertSeries() +{ + d->canvas->closeEditor(); + SeriesDlg dlg( this, "Series", TQPoint( d->canvas->markerColumn(), d->canvas->markerRow() ) ); + dlg.exec(); +} + +void View::sort() +{ + if ( d->selection->isSingular() ) + { + KMessageBox::error( this, i18n("You must select multiple cells.") ); + return; + } + + SortDialog dlg( this, "Sort" ); + dlg.exec(); +} + +void View::removeHyperlink() +{ + TQPoint marker( d->selection->marker() ); + Cell * cell = d->activeSheet->cellAt( marker ); + if( !cell ) return; + if( cell->link().isEmpty() ) return; + + LinkCommand* command = new LinkCommand( cell, TQString(), TQString() ); + doc()->addCommand( command ); + command->execute(); + + canvasWidget()->setFocus(); + d->editWidget->setText( cell->text() ); +} + +void View::insertHyperlink() +{ + if (!activeSheet()) + return; + + d->canvas->closeEditor(); + + TQPoint marker( d->selection->marker() ); + Cell* cell = d->activeSheet->cellAt( marker ); + + LinkDialog* dlg = new LinkDialog( this ); + dlg->setCaption( i18n( "Insert Link" ) ); + if( cell ) + { + dlg->setText( cell->text() ); + if( !cell->link().isEmpty() ) + { + dlg->setCaption( i18n( "Edit Link" ) ); + dlg->setLink( cell->link() ); + } + } + + if( dlg->exec() == KDialog::Accepted ) + { + cell = d->activeSheet->nonDefaultCell( marker ); + + LinkCommand* command = new LinkCommand( cell, dlg->text(), dlg->link() ); + doc()->addCommand( command ); + command->execute(); + + //refresh editWidget + canvasWidget()->setFocus(); + d->editWidget->setText( cell->text() ); + } + delete dlg; +} + +void View::insertFromDatabase() +{ +#ifndef TQT_NO_SQL + d->canvas->closeEditor(); + + TQRect rect = d->selection->selection(); + + TQStringList str = TQSqlDatabase::drivers(); + if ( str.isEmpty() ) + { + KMessageBox::error( this, i18n("No database drivers available. To use this feature you need " + "to install the necessary TQt 3 database drivers.") ); + + return; + } + + doc()->doNotPaint( true ); + DatabaseDialog dlg(this, rect, "DatabaseDialog"); + dlg.exec(); + doc()->doNotPaint( false ); +#endif +} + +void View::insertFromTextfile() +{ + d->canvas->closeEditor(); + //KMessageBox::information( this, "Not implemented yet, work in progress..."); + doc()->doNotPaint( true ); + CSVDialog dialog( this, "CSVDialog", d->selection->selection(), CSVDialog::File ); + if( !dialog.cancelled() ) + dialog.exec(); + doc()->doNotPaint( false ); +} + +void View::insertFromClipboard() +{ + d->canvas->closeEditor(); + doc()->doNotPaint( true ); + CSVDialog dialog( this, "CSVDialog", d->selection->selection(), CSVDialog::Clipboard ); + if( !dialog.cancelled() ) + dialog.exec(); + doc()->doNotPaint( false ); +} + +void View::setupPrinter( KPrinter &prt ) +{ + if (!activeSheet()) + return; + + SheetPrint* print = d->activeSheet->print(); + + //apply page layout parameters + KoFormat pageFormat = print->paperFormat(); + + prt.setPageSize( static_cast<KPrinter::PageSize>( KoPageFormat::printerPageSize( pageFormat ) ) ); + + if ( print->orientation() == PG_LANDSCAPE || pageFormat == PG_SCREEN ) + prt.setOrientation( KPrinter::Landscape ); + else + prt.setOrientation( KPrinter::Portrait ); + + prt.setFullPage( true ); + + //add possibility to select the sheets to print: +// kdDebug() << "Adding sheet selection page." << endl; + KPSheetSelectPage* sheetpage = new KPSheetSelectPage(); + prt.addDialogPage(sheetpage); + +// kdDebug() << "Iterating through available sheets and initializing list of available sheets." << endl; + TQPtrList<Sheet> sheetlist = doc()->map()->sheetList(); + Sheet* sheet = sheetlist.last(); + while ( sheet ) + { + kdDebug() << "Adding " << sheet->sheetName() << endl; + sheetpage->prependAvailableSheet(sheet->sheetName()); + sheet = sheetlist.prev(); + } +} + +void View::print( KPrinter &prt ) +{ + if (!activeSheet()) + return; + + //save the current active sheet for later, so we can restore it at the end + Sheet* selectedsheet = this->activeSheet(); + + //print all sheets in the order given by the print dialog (Sheet Selection) + TQStringList sheetlist = KPSheetSelectPage::selectedSheets(prt); + + if (sheetlist.empty()) + { + kdDebug() << "No sheet for printing selected, printing active sheet" << endl; + sheetlist.append(d->activeSheet->sheetName()); + } + + TQPainter painter; + painter.begin( &prt ); + + bool firstpage = true; + + TQStringList::iterator sheetlistiterator; + for (sheetlistiterator = sheetlist.begin(); sheetlistiterator != sheetlist.end(); ++sheetlistiterator) + { + kdDebug() << " printing sheet " << *sheetlistiterator << endl; + Sheet* sheet = doc()->map()->findSheet(*sheetlistiterator); + if (sheet == NULL) + { + kdWarning() << i18n("Sheet %1 could not be found for printing").arg(*sheetlistiterator) << endl; + continue; + } + + setActiveSheet(sheet,FALSE); + + SheetPrint* print = d->activeSheet->print(); + + if (firstpage) + firstpage=false; + else + { + kdDebug() << " inserting new page" << endl; + prt.newPage(); + } + + if ( d->canvas->editor() ) + { + d->canvas->deleteEditor( true ); // save changes + } + + int oldZoom = doc()->zoom(); + + //Comment from KWord + // We don't get valid metrics from the printer - and we want a better resolution + // anyway (it's the PS driver that takes care of the printer resolution). + //But KSpread uses fixed 300 dpis, so we can use it. + + TQPaintDeviceMetrics metrics( &prt ); + + int dpiX = metrics.logicalDpiX(); + int dpiY = metrics.logicalDpiY(); + + doc()->setZoomAndResolution( int( print->zoom() * 100 ), dpiX, dpiY ); + + //store the current setting in a temporary variable + KoOrientation _orient = print->orientation(); + + //use the current orientation from print dialog + if ( prt.orientation() == KPrinter::Landscape ) + { + print->setPaperOrientation( PG_LANDSCAPE ); + } + else + { + print->setPaperOrientation( PG_PORTRAIT ); + } + + bool result = print->print( painter, &prt ); + + //Restore original orientation + print->setPaperOrientation( _orient ); + + doc()->setZoomAndResolution( oldZoom, KoGlobal::dpiX(), KoGlobal::dpiY() ); + doc()->newZoomAndResolution( true, false ); + + // Repaint at correct zoom + doc()->emitBeginOperation( false ); + setZoom( oldZoom, false ); + doc()->emitEndOperation(); + + // Nothing to print + if( !result ) + { + if( !prt.previewOnly() ) + { + KMessageBox::information( 0, + i18n("Nothing to print for sheet %1.").arg( + d->activeSheet->sheetName()) ); + //@todo: make sure we really can comment this out, + // what to do with partially broken printouts? +// prt.abort(); + } + } + } + + painter.end(); + this->setActiveSheet(selectedsheet); +} + +void View::insertChart( const TQRect& _geometry, KoDocumentEntry& _e ) +{ + if ( !d->activeSheet ) + return; + + // Transform the view coordinates to document coordinates + KoRect unzoomedRect = doc()->unzoomRect( _geometry ); + unzoomedRect.moveBy( d->canvas->xOffset(), d->canvas->yOffset() ); + + InsertObjectCommand *cmd = 0; + if ( d->selection->isColumnOrRowSelected() ) + { + KMessageBox::error( this, i18n("Area is too large.")); + return; + } + else + cmd = new InsertObjectCommand( unzoomedRect, _e, d->selection->selection(), d->canvas ); + + doc()->addCommand( cmd ); + cmd->execute(); +} + +void View::insertChild( const TQRect& _geometry, KoDocumentEntry& _e ) +{ + if ( !d->activeSheet ) + return; + + // Transform the view coordinates to document coordinates + KoRect unzoomedRect = doc()->unzoomRect( _geometry ); + unzoomedRect.moveBy( d->canvas->xOffset(), d->canvas->yOffset() ); + + InsertObjectCommand *cmd = new InsertObjectCommand( unzoomedRect, _e, d->canvas ); + doc()->addCommand( cmd ); + cmd->execute(); +} + +KoPoint View::markerDocumentPosition() +{ + TQPoint marker=selectionInfo()->marker(); + + return KoPoint( d->activeSheet->dblColumnPos(marker.x()), + d->activeSheet->dblRowPos(marker.y()) ); +} + +void View::insertPicture() +{ + //Note: We don't use the usual insert handler here (which allows the user to drag-select the target area + //for the object) because when inserting raster graphics, it is usually desireable to insert at 100% size, + //since the graphic won't look right if inserted with an incorrect aspect ratio or if blurred due to the + //scaling. If the user wishes to change the size and/or aspect ratio, they can do that afterwards. + //This behaviour can be seen in other spreadsheets. + //-- Robert Knight 12/02/06 <robertknight@gmail.com> + + KURL file = KFileDialog::getImageOpenURL( TQString(), d->canvas ); + + if (file.isEmpty()) + return; + + if ( !d->activeSheet ) + return; + + InsertObjectCommand *cmd = new InsertObjectCommand( KoRect(markerDocumentPosition(),KoSize(0,0)) , file, d->canvas ); + doc()->addCommand( cmd ); + cmd->execute(); +} + +void View::slotUpdateChildGeometry( EmbeddedKOfficeObject */*_child*/ ) +{ + // ############## + // TODO + /* + if ( _child->sheet() != d->activeSheet ) + return; + + // Find frame for child + ChildFrame *f = 0L; + TQPtrListIterator<ChildFrame> it( m_lstFrames ); + for ( ; it.current() && !f; ++it ) + if ( it.current()->child() == _child ) + f = it.current(); + + assert( f != 0L ); + + // Are we already up to date ? + if ( _child->geometry() == f->partGeometry() ) + return; + + // TODO zooming + f->setPartGeometry( _child->geometry() ); + */ +} + +void View::toggleProtectDoc( bool mode ) +{ + if ( !doc() || !doc()->map() ) + return; + + TQString password; + if ( mode ) + { + int result = KPasswordDialog::getNewPassword( password, i18n( "Protect Document" ) ); + if ( result != KPasswordDialog::Accepted ) + { + d->actions->protectDoc->setChecked( false ); + return; + } + + TQCString hash( "" ); + if ( password.length() > 0 ) + SHA1::getHash( password, hash ); + doc()->map()->setProtected( hash ); + } + else + { + int result = KPasswordDialog::getPassword( password, i18n( "Unprotect Document" ) ); + if ( result != KPasswordDialog::Accepted ) + { + d->actions->protectDoc->setChecked( true ); + return; + } + + TQCString hash( "" ); + if ( password.length() > 0 ) + SHA1::getHash( password, hash ); + if ( !doc()->map()->checkPassword( hash ) ) + { + KMessageBox::error( 0, i18n( "Password is incorrect." ) ); + d->actions->protectDoc->setChecked( true ); + return; + } + + doc()->map()->setProtected( TQCString() ); + } + + doc()->setModified( true ); + d->adjustWorkbookActions( !mode ); +} + +void View::toggleProtectSheet( bool mode ) +{ + if ( !d->activeSheet ) + return; + + TQString password; + if ( mode ) + { + int result = KPasswordDialog::getNewPassword( password, i18n( "Protect Sheet" ) ); + if ( result != KPasswordDialog::Accepted ) + { + d->actions->protectSheet->setChecked( false ); + return; + } + + TQCString hash( "" ); + if ( password.length() > 0 ) + SHA1::getHash( password, hash ); + + d->activeSheet->setProtected( hash ); + } + else + { + int result = KPasswordDialog::getPassword( password, i18n( "Unprotect Sheet" ) ); + if ( result != KPasswordDialog::Accepted ) + { + d->actions->protectSheet->setChecked( true ); + return; + } + + TQCString hash( "" ); + if ( password.length() > 0 ) + SHA1::getHash( password, hash ); + + if ( !d->activeSheet->checkPassword( hash ) ) + { + KMessageBox::error( 0, i18n( "Password is incorrect." ) ); + d->actions->protectSheet->setChecked( true ); + return; + } + + d->activeSheet->setProtected( TQCString() ); + } + doc()->setModified( true ); + d->adjustActions( !mode ); + doc()->emitBeginOperation(); + // d->activeSheet->setRegionPaintDirty( TQRect(TQPoint( 0, 0 ), TQPoint( KS_colMax, KS_rowMax ) ) ); + refreshView(); + updateEditWidget(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::togglePageBorders( bool mode ) +{ + if ( !d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->setShowPageBorders( mode ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::viewZoom( const TQString & s ) +{ + + int oldZoom = doc()->zoom(); + + bool ok = false; + TQRegExp regexp("(\\d+)"); // "Captured" non-empty sequence of digits + regexp.search(s); + int newZoom=regexp.cap(1).toInt(&ok); + if ( !ok || newZoom < 10 ) //zoom should be valid and >10 + newZoom = oldZoom; + if ( newZoom != oldZoom ) + { + d->actions->viewZoom->setZoom( newZoom ); + + doc()->emitBeginOperation( false ); + + d->canvas->closeEditor(); + setZoom( newZoom, true ); + + if (activeSheet()) + { + TQRect r( d->activeSheet->visibleRect( d->canvas ) ); + r.setWidth( r.width() + 2 ); + doc()->emitEndOperation( r ); + } + } +} + +void View::setZoom( int zoom, bool /*updateViews*/ ) +{ + kdDebug() << "---------SetZoom: " << zoom << endl; + + // Set the zoom in KoView (for embedded views) + doc()->emitBeginOperation( false ); + + doc()->setZoomAndResolution( zoom, KoGlobal::dpiX(), KoGlobal::dpiY()); + //KoView::setZoom( doc()->zoomedResolutionY() /* KoView only supports one zoom */ ); + + Q_ASSERT(d->activeSheet); + + if (d->activeSheet) //this is 0 when viewing a document in konqueror!? (see Q_ASSERT above) + d->activeSheet->setRegionPaintDirty(TQRect(TQPoint(0,0), TQPoint(KS_colMax, KS_rowMax))); + + doc()->refreshInterface(); + doc()->emitEndOperation(); +} + +void View::showStatusBar( bool b ) +{ + doc()->setShowStatusBar( b ); + refreshView(); +} + +void View::showTabBar( bool b ) +{ + doc()->setShowTabBar( b ); + refreshView(); +} + +void View::showFormulaBar( bool b ) +{ + doc()->setShowFormulaBar( b ); + refreshView(); +} + +void View::preference() +{ + if ( !d->activeSheet ) + return; + + PreferenceDialog dlg( this, "Preference" ); + if ( dlg.exec() ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->refreshPreference(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::addModifyComment() +{ + if ( !d->activeSheet ) + return; + + CommentDialog dlg( this, "comment", + TQPoint( d->canvas->markerColumn(), + d->canvas->markerRow() ) ); + if ( dlg.exec() ) + updateEditWidget(); +} + +void View::setSelectionComment( TQString comment ) +{ + if ( d->activeSheet != NULL ) + { + doc()->emitBeginOperation( false ); + + d->activeSheet->setSelectionComment( selectionInfo(), comment.stripWhiteSpace() ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::editCell() +{ + if ( d->canvas->editor() ) + return; + + d->canvas->createEditor(true); +} + +bool View::showSheet(const TQString& sheetName) { + Sheet *t=doc()->map()->findSheet(sheetName); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " <<sheetName<< endl; + return false; + } + d->canvas->closeEditor(); + setActiveSheet( t ); + + return true; +} + +void View::nextSheet() +{ + Sheet * t = doc()->map()->nextSheet( activeSheet() ); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " << endl; + return; + } + d->canvas->closeEditor(); + setActiveSheet( t ); + d->tabBar->setActiveTab( t->sheetName() ); + d->tabBar->ensureVisible( t->sheetName() ); +} + +void View::previousSheet() +{ + Sheet * t = doc()->map()->previousSheet( activeSheet() ); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " << endl; + return; + } + d->canvas->closeEditor(); + setActiveSheet( t ); + d->tabBar->setActiveTab( t->sheetName() ); + d->tabBar->ensureVisible( t->sheetName() ); +} + +void View::firstSheet() +{ + Sheet *t = doc()->map()->firstSheet(); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " << endl; + return; + } + d->canvas->closeEditor(); + setActiveSheet( t ); + d->tabBar->setActiveTab( t->sheetName() ); + d->tabBar->ensureVisible( t->sheetName() ); +} + +void View::lastSheet() +{ + Sheet *t = doc()->map()->lastSheet( ); + if ( !t ) + { + kdDebug(36001) << "Unknown sheet " << endl; + return; + } + d->canvas->closeEditor(); + setActiveSheet( t ); + d->tabBar->setActiveTab( t->sheetName() ); + d->tabBar->ensureVisible( t->sheetName() ); +} + +void View::keyPressEvent ( TQKeyEvent* _ev ) +{ + // Dont eat accelerators + if ( _ev->state() & ( TQt::AltButton | TQt::ControlButton ) ) + { + if ( _ev->state() & ( TQt::ControlButton ) ) + { + switch( _ev->key() ) + { +#ifndef NDEBUG + case TQt::Key_V: // Ctrl+Shift+V to show debug (similar to KWord) + if ( _ev->state() & TQt::ShiftButton ) + d->activeSheet->printDebug(); +#endif + default: + TQWidget::keyPressEvent( _ev ); + return; + } + } + TQWidget::keyPressEvent( _ev ); + } + else + TQApplication::sendEvent( d->canvas, _ev ); +} + +KoDocument * View::hitTest( const TQPoint& /*pos*/ ) +{ +// // Code copied from KoView::hitTest +// KoViewChild *viewChild; +// +// TQWMatrix m = matrix(); +// m.translate( d->canvas->xOffset() / doc()->zoomedResolutionX(), +// d->canvas->yOffset() / doc()->zoomedResolutionY() ); +// +// KoDocumentChild *docChild = selectedChild(); +// if ( docChild ) +// { +// if ( ( viewChild = child( docChild->document() ) ) ) +// { +// if ( viewChild->frameRegion( m ).contains( pos ) ) +// return 0; +// } +// else +// if ( docChild->frameRegion( m ).contains( pos ) ) +// return 0; +// } +// +// docChild = activeChild(); +// if ( docChild ) +// { +// if ( ( viewChild = child( docChild->document() ) ) ) +// { +// if ( viewChild->frameRegion( m ).contains( pos ) ) +// return 0; +// } +// else +// if ( docChild->frameRegion( m ).contains( pos ) ) +// return 0; +// } +// +// TQPtrListIterator<KoDocumentChild> it( doc()->children() ); +// for (; it.current(); ++it ) +// { +// // Is the child document on the visible sheet ? +// if ( ((EmbeddedKOfficeObject*)it.current())->sheet() == d->activeSheet ) +// { +// KoDocument *doc = it.current()->hitTest( pos, m ); +// if ( doc ) +// return doc; +// } +// } +// + return doc(); +} + +int View::leftBorder() const +{ + return int( d->canvas->doc()->zoomItX( YBORDER_WIDTH ) ); +} + +int View::rightBorder() const +{ + return d->vertScrollBar->width(); +} + +int View::topBorder() const +{ + return d->toolWidget->height() + int( d->canvas->doc()->zoomItX( Format::globalRowHeight() + 2 ) ); +} + +int View::bottomBorder() const +{ + return d->horzScrollBar->height(); +} + +void View::refreshView() +{ + kdDebug() << "refreshing view" << endl; + + Sheet * sheet = activeSheet(); + if ( !sheet ) + return; + + d->adjustActions( !sheet->isProtected() ); + d->actions->viewZoom->setZoom( doc()->zoom() ); + + bool active = sheet->getShowFormula(); + if ( sheet && !sheet->isProtected() ) + { + d->actions->alignLeft->setEnabled( !active ); + d->actions->alignCenter->setEnabled( !active ); + d->actions->alignRight->setEnabled( !active ); + } + + d->tabBar->setReadOnly( !doc()->isReadWrite() || doc()->map()->isProtected() ); + + d->toolWidget->setShown( doc()->showFormulaBar() ); + d->editWidget->showEditWidget( doc()->showFormulaBar() ); + d->hBorderWidget->setShown( doc()->showColumnHeader() ); + d->vBorderWidget->setShown( doc()->showRowHeader() ); + d->vertScrollBar->setShown( doc()->showVerticalScrollBar() ); + d->horzScrollBar->setShown( doc()->showHorizontalScrollBar() ); + d->tabBar->setShown( doc()->showTabBar() ); + if ( statusBar() ) statusBar()->setShown( doc()->showStatusBar() ); + + d->canvas->updatePosWidget(); + + d->hBorderWidget->setMinimumHeight( doc()->zoomItY( KoGlobal::defaultFont().pointSizeFloat() + 5 ) ); + d->vBorderWidget->setMinimumWidth( doc()->zoomItX( YBORDER_WIDTH ) ); + + Sheet::LayoutDirection sheetDir = sheet->layoutDirection(); + bool interfaceIsRTL = TQApplication::reverseLayout(); + + kdDebug()<<" sheetDir == Sheet::LeftToRight :"<<( sheetDir == Sheet::LeftToRight )<<endl; + if ((sheetDir == Sheet::LeftToRight && !interfaceIsRTL) || + (sheetDir == Sheet::RightToLeft && interfaceIsRTL)) + { + d->formulaBarLayout->setDirection( TQBoxLayout::LeftToRight ); + d->viewLayout->setOrigin( TQGridLayout::TopLeft ); + d->tabScrollBarLayout->setDirection( TQBoxLayout::LeftToRight ); + d->tabBar->setReverseLayout( interfaceIsRTL ); + } + else + { + d->formulaBarLayout->setDirection( TQBoxLayout::RightToLeft ); + d->viewLayout->setOrigin( TQGridLayout::TopRight ); + d->tabScrollBarLayout->setDirection( TQBoxLayout::RightToLeft ); + d->tabBar->setReverseLayout( !interfaceIsRTL ); + } +} + +void View::resizeEvent( TQResizeEvent * ) +{ +} + +void View::popupChildMenu( KoChild* child, const TQPoint& /*global_pos*/ ) +{ + if ( !child ) + return; + + delete d->popupChild; + +// d->popupChildObject = static_cast<EmbeddedKOfficeObject*>(child); +// +// d->popupChild = new TQPopupMenu( this ); +// +// d->popupChild->insertItem( i18n("Delete Embedded Document"), this, TQT_SLOT( slotPopupDeleteChild() ) ); +// +// d->popupChild->popup( global_pos ); + +} + +void View::slotPopupDeleteChild() +{ +// if ( !d->popupChildObject || !d->popupChildObject->sheet() ) +// return; + + //Removed popup warning dialog because + // a) It is annoying from a user's persepective + // b) The behaviour should be consistant with other KOffice apps + + /*int ret = KMessageBox::warningContinueCancel(this,i18n("You are about to remove this embedded document.\nDo you want to continue?"),i18n("Delete Embedded Document"),KGuiItem(i18n("&Delete"),"edit-delete")); + if ( ret == KMessageBox::Continue ) + { + +}*/ +// doc()->emitBeginOperation(false); +// d->popupChildObject->sheet()->deleteChild( d->popupChildObject ); +// d->popupChildObject = 0; +// doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::popupColumnMenu( const TQPoint & _point ) +{ + assert( d->activeSheet ); + + if ( !koDocument()->isReadWrite() ) + return; + + delete d->popupColumn ; + + d->popupColumn = new TQPopupMenu( this ); + + bool isProtected = d->activeSheet->isProtected(); + + if ( !isProtected ) + { + d->actions->cellLayout->plug( d->popupColumn ); + d->popupColumn->insertSeparator(); + d->actions->cut->plug( d->popupColumn ); + } + d->actions->copy->plug( d->popupColumn ); + if ( !isProtected ) + { + d->actions->paste->plug( d->popupColumn ); + d->actions->specialPaste->plug( d->popupColumn ); + d->actions->insertCellCopy->plug( d->popupColumn ); + d->popupColumn->insertSeparator(); + d->actions->defaultFormat->plug( d->popupColumn ); + // If there is no selection + if (!d->selection->isColumnOrRowSelected()) + { + d->actions->areaName->plug( d->popupColumn ); + } + + d->actions->resizeColumn->plug( d->popupColumn ); + d->popupColumn->insertItem( i18n("Adjust Column"), this, TQT_SLOT(slotPopupAdjustColumn() ) ); + d->popupColumn->insertSeparator(); + d->actions->insertColumn->plug( d->popupColumn ); + d->actions->deleteColumn->plug( d->popupColumn ); + d->actions->hideColumn->plug( d->popupColumn ); + + d->actions->showSelColumns->setEnabled(false); + + ColumnFormat* format; + //kdDebug(36001) << "Column: L: " << rect.left() << endl; + Region::ConstIterator endOfList = d->selection->constEnd(); + for (Region::ConstIterator it = d->selection->constBegin(); it != endOfList; ++it) + { + TQRect range = (*it)->rect().normalize(); + int col; + for (col = range.left(); col < range.right(); ++col) + { + format = activeSheet()->columnFormat(col); + + if ( format->isHide() ) + { + d->actions->showSelColumns->setEnabled( true ); + d->actions->showSelColumns->plug( d->popupColumn ); + break; + } + } + if (range.left() > 1 && col == range.right()) + { + bool allHidden = true; + for (col = 1; col < range.left(); ++col) + { + format = activeSheet()->columnFormat(col); + + allHidden &= format->isHide(); + } + if (allHidden) + { + d->actions->showSelColumns->setEnabled( true ); + d->actions->showSelColumns->plug( d->popupColumn ); + break; + } + } + else + { + break; + } + } + } + + TQT_BASE_OBJECT_NAME::connect( d->popupColumn, TQT_SIGNAL(activated( int ) ), this, TQT_SLOT( slotActivateTool( int ) ) ); + + d->popupColumn->popup( _point ); +} + +void View::slotPopupAdjustColumn() +{ + if ( !d->activeSheet ) + return; + + d->activeSheet->adjustColumn(*selectionInfo()); +} + +void View::popupRowMenu( const TQPoint & _point ) +{ + assert( d->activeSheet ); + + if ( !koDocument()->isReadWrite() ) + return; + + delete d->popupRow ; + + d->popupRow= new TQPopupMenu(); + + bool isProtected = d->activeSheet->isProtected(); + + if ( !isProtected ) + { + d->actions->cellLayout->plug( d->popupRow ); + d->popupRow->insertSeparator(); + d->actions->cut->plug( d->popupRow ); + } + d->actions->copy->plug( d->popupRow ); + if ( !isProtected ) + { + d->actions->paste->plug( d->popupRow ); + d->actions->specialPaste->plug( d->popupRow ); + d->actions->insertCellCopy->plug( d->popupRow ); + d->popupRow->insertSeparator(); + d->actions->defaultFormat->plug( d->popupRow ); + // If there is no selection + if (!d->selection->isColumnOrRowSelected()) + { + d->actions->areaName->plug(d->popupRow); + } + + d->actions->resizeRow->plug( d->popupRow ); + d->popupRow->insertItem( i18n("Adjust Row"), this, TQT_SLOT( slotPopupAdjustRow() ) ); + d->popupRow->insertSeparator(); + d->actions->insertRow->plug( d->popupRow ); + d->actions->deleteRow->plug( d->popupRow ); + d->actions->hideRow->plug( d->popupRow ); + + d->actions->showSelColumns->setEnabled(false); + + RowFormat* format; + Region::ConstIterator endOfList = d->selection->constEnd(); + for (Region::ConstIterator it = d->selection->constBegin(); it != endOfList; ++it) + { + TQRect range = (*it)->rect().normalize(); + int row; + for (row = range.top(); row < range.bottom(); ++row) + { + format = activeSheet()->rowFormat(row); + + if ( format->isHide() ) + { + d->actions->showSelRows->setEnabled( true ); + d->actions->showSelRows->plug( d->popupRow ); + break; + } + } + if (range.top() > 1 && row == range.bottom()) + { + bool allHidden = true; + for (row = 1; row < range.top(); ++row) + { + format = activeSheet()->rowFormat(row); + + allHidden &= format->isHide(); + } + if (allHidden) + { + d->actions->showSelRows->setEnabled( true ); + d->actions->showSelRows->plug( d->popupRow ); + break; + } + } + else + { + break; + } + } + } + + TQT_BASE_OBJECT_NAME::connect( d->popupRow, TQT_SIGNAL( activated( int ) ), this, TQT_SLOT( slotActivateTool( int ) ) ); + d->popupRow->popup( _point ); +} + +void View::slotPopupAdjustRow() +{ + if ( !d->activeSheet ) + return; + + d->activeSheet->adjustRow(*selectionInfo()); +} + + +void View::slotListChoosePopupMenu( ) +{ + if ( !koDocument()->isReadWrite() ) + return; + + assert( d->activeSheet ); + delete d->popupListChoose; + + d->popupListChoose = new TQPopupMenu(); + int id = 0; + TQRect selection( d->selection->selection() ); + Cell * cell = d->activeSheet->cellAt( d->canvas->markerColumn(), d->canvas->markerRow() ); + TQString tmp = cell->text(); + TQStringList itemList; + + for ( int col = selection.left(); col <= selection.right(); ++col ) + { + Cell * c = d->activeSheet->getFirstCellColumn( col ); + while ( c ) + { + if ( !c->isPartOfMerged() + && !( col == d->canvas->markerColumn() + && c->row() == d->canvas->markerRow()) ) + { + if ( c->value().isString() && c->text() != tmp && !c->text().isEmpty() ) + { + if ( itemList.findIndex( c->text() ) == -1 ) + itemList.append(c->text()); + } + } + + c = d->activeSheet->getNextCellDown( col, c->row() ); + } + } + + /* TODO: remove this later: + for( ;c; c = c->nextCell() ) + { + int col = c->column(); + if ( selection.left() <= col && selection.right() >= col + &&!c->isPartOfMerged()&& !(col==d->canvas->markerColumn()&& c->row()==d->canvas->markerRow())) + { + if (c->isString() && c->text()!=tmp && !c->text().isEmpty()) + { + if (itemList.findIndex(c->text())==-1) + itemList.append(c->text()); + } + + } + } + */ + + for ( TQStringList::Iterator it = itemList.begin(); it != itemList.end();++it ) + d->popupListChoose->insertItem( (*it), id++ ); + + if ( id == 0 ) + return; + RowFormat * rl = d->activeSheet->rowFormat( d->canvas->markerRow()); + double tx = d->activeSheet->dblColumnPos( d->canvas->markerColumn(), d->canvas ); + double ty = d->activeSheet->dblRowPos(d->canvas->markerRow(), d->canvas ); + double h = rl->dblHeight( d->canvas ); + if ( cell->extraYCells() ) + h = cell->extraHeight(); + ty += h; + + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + { + tx = canvasWidget()->width() - tx; + } + + TQPoint p( (int)tx, (int)ty ); + TQPoint p2 = d->canvas->mapToGlobal( p ); + + if ( d->activeSheet->layoutDirection()==Sheet::RightToLeft ) + { + p2.setX( p2.x() - d->popupListChoose->sizeHint().width() + 1 ); + } + + d->popupListChoose->popup( p2 ); + TQT_BASE_OBJECT_NAME::connect( d->popupListChoose, TQT_SIGNAL( activated( int ) ), + this, TQT_SLOT( slotItemSelected( int ) ) ); +} + + +void View::slotItemSelected( int id ) +{ + TQString tmp = d->popupListChoose->text( id ); + int x = d->canvas->markerColumn(); + int y = d->canvas->markerRow(); + Cell * cell = d->activeSheet->nonDefaultCell( x, y ); + + if ( tmp == cell->text() ) + return; + + doc()->emitBeginOperation( false ); + + if ( !doc()->undoLocked() ) + { + UndoSetText* undo = new UndoSetText( doc(), d->activeSheet, cell->text(), + x, y, cell->formatType() ); + doc()->addCommand( undo ); + } + + cell->setCellText( tmp ); + d->editWidget->setText( tmp ); + + doc()->emitEndOperation( TQRect( x, y, 1, 1 ) ); +} + +void View::openPopupMenu( const TQPoint & _point ) +{ + assert( d->activeSheet ); + delete d->popupMenu; + + if ( !koDocument()->isReadWrite() ) + return; + + d->popupMenu = new TQPopupMenu(); + + EmbeddedObject *obj; + if ( d->canvas->isObjectSelected() && ( obj = d->canvas->getObject( d->canvas->mapFromGlobal( _point ), d->activeSheet ) ) && obj->isSelected() ) + { + d->actions->deleteCell->plug( d->popupMenu ); + d->popupMenu->insertSeparator(); + d->actions->cut->plug( d->popupMenu ); + d->actions->copy->plug( d->popupMenu ); + d->actions->paste->plug( d->popupMenu ); + d->popupMenu->popup( _point ); + d->popupMenu->insertSeparator(); + d->actions->actionExtraProperties->plug( d->popupMenu ); + return; + } + + Cell * cell = d->activeSheet->cellAt( d->canvas->markerColumn(), d->canvas->markerRow() ); + + bool isProtected = d->activeSheet->isProtected(); + if ( !cell->isDefault() && cell->format()->notProtected( d->canvas->markerColumn(), d->canvas->markerRow() ) + && d->selection->isSingular() ) + isProtected = false; + + if ( !isProtected ) + { + d->actions->cellLayout->plug( d->popupMenu ); + d->popupMenu->insertSeparator(); + d->actions->cut->plug( d->popupMenu ); + } + d->actions->copy->plug( d->popupMenu ); + if ( !isProtected ) + d->actions->paste->plug( d->popupMenu ); + + if ( !isProtected ) + { + d->actions->specialPaste->plug( d->popupMenu ); + d->actions->insertCellCopy->plug( d->popupMenu ); + d->popupMenu->insertSeparator(); + d->actions->deleteCell->plug( d->popupMenu ); + d->actions->adjust->plug( d->popupMenu ); + d->actions->defaultFormat->plug( d->popupMenu ); + + // If there is no selection + if (!d->selection->isColumnOrRowSelected()) + { + d->actions->areaName->plug( d->popupMenu ); + d->popupMenu->insertSeparator(); + d->actions->insertCell->plug( d->popupMenu ); + d->actions->removeCell->plug( d->popupMenu ); + } + + d->popupMenu->insertSeparator(); + d->actions->addModifyComment->plug( d->popupMenu ); + if ( !cell->format()->comment(d->canvas->markerColumn(), d->canvas->markerRow()).isEmpty() ) + { + d->actions->removeComment->plug( d->popupMenu ); + } + + if (activeSheet()->testListChoose(selectionInfo())) + { + d->popupMenu->insertSeparator(); + d->popupMenu->insertItem( i18n("Selection List..."), this, TQT_SLOT( slotListChoosePopupMenu() ) ); + } + } + + // Remove informations about the last tools we offered + d->toolList.clear(); + d->toolList.setAutoDelete( true ); + + if ( !isProtected && !activeSheet()->getWordSpelling( selectionInfo() ).isEmpty() ) + { + d->popupMenuFirstToolId = 10; + int i = 0; + TQValueList<KDataToolInfo> tools = KDataToolInfo::query( TQSTRING_OBJECT_NAME_STRING, "text/plain", doc()->instance() ); + if ( tools.count() > 0 ) + { + d->popupMenu->insertSeparator(); + TQValueList<KDataToolInfo>::Iterator entry = tools.begin(); + for( ; entry != tools.end(); ++entry ) + { + TQStringList lst = (*entry).userCommands(); + TQStringList::ConstIterator it = lst.begin(); + + // ### Torben: Insert pixmaps here, too + for (; it != lst.end(); ++it ) + d->popupMenu->insertItem( *it, d->popupMenuFirstToolId + i++ ); + + lst = (*entry).commands(); + it = lst.begin(); + for (; it != lst.end(); ++it ) + { + Private::ToolEntry *t = new Private::ToolEntry; + t->command = *it; + t->info = *entry; + d->toolList.append( t ); + } + } + + TQT_BASE_OBJECT_NAME::connect( d->popupMenu, TQT_SIGNAL( activated( int ) ), this, TQT_SLOT( slotActivateTool( int ) ) ); + } + } + + d->popupMenu->popup( _point ); +} + +void View::slotActivateTool( int _id ) +{ + if (!activeSheet()) return; + + // Is it the id of a tool in the latest popupmenu ? + if ( _id < d->popupMenuFirstToolId ) + return; + + Private::ToolEntry* entry = d->toolList.at( _id - d->popupMenuFirstToolId ); + + KDataTool* tool = entry->info.createTool(); + if ( !tool ) + { + kdDebug(36001) << "Could not create Tool" << endl; + return; + } + + TQString text = activeSheet()->getWordSpelling( selectionInfo() ); + + if ( tool->run( entry->command, &text, TQSTRING_OBJECT_NAME_STRING, "text/plain") ) + { + doc()->emitBeginOperation(false); + + activeSheet()->setWordSpelling( selectionInfo(), text); + + Cell *cell = d->activeSheet->cellAt( d->canvas->markerColumn(), d->canvas->markerRow() ); + d->editWidget->setText( cell->text() ); + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::deleteSelection() +{ + if (!activeSheet()) return; + + if ( canvasWidget()->isObjectSelected() ) + { + deleteSelectedObjects(); + return; + } + + doc()->emitBeginOperation( false ); + d->activeSheet->deleteSelection( selectionInfo() ); + calcStatusBarOp(); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::deleteSelectedObjects() +{ + KMacroCommand * macroCommand = 0L; + TQPtrListIterator<EmbeddedObject> it( doc()->embeddedObjects() ); + for ( ; it.current() ; ++it ) + { + if ( it.current()->sheet() == canvasWidget()->activeSheet() && it.current()->isSelected() ) + { + // d->activeSheet->setRegionPaintDirty( it. + if( !macroCommand ) + macroCommand = new KMacroCommand( i18n( "Remove Object" ) ); + RemoveObjectCommand *cmd = new RemoveObjectCommand( it.current() ); + macroCommand->addCommand( cmd ); + } + } + if ( macroCommand ) + { + doc()->addCommand( macroCommand ); + canvasWidget()->setMouseSelectedObject( false ); + macroCommand->execute(); + } +} + +void View::adjust() +{ + if ( !d->activeSheet ) + return; + + d->activeSheet->adjustArea(*selectionInfo()); +} + +void View::clearTextSelection() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->clearTextSelection( selectionInfo() ); + + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::clearCommentSelection() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->setSelectionRemoveComment( selectionInfo() ); + + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::clearValiditySelection() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->clearValiditySelection( selectionInfo() ); + + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::clearConditionalSelection() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->clearConditionalSelection( selectionInfo() ); + + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::fillRight() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->fillSelection( selectionInfo(), Sheet::Right ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::fillLeft() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->fillSelection( selectionInfo(), Sheet::Left ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::fillUp() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->fillSelection( selectionInfo(), Sheet::Up ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::fillDown() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->fillSelection( selectionInfo(), Sheet::Down ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::defaultSelection() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + d->activeSheet->defaultSelection( selectionInfo() ); + + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::slotInsert() +{ + TQRect r( d->selection->selection() ); + InsertDialog dlg( this, "InsertDialog", r, InsertDialog::Insert ); + dlg.exec(); +} + +void View::slotRemove() +{ + TQRect r( d->selection->selection() ); + InsertDialog dlg( this, "Remove", r, InsertDialog::Remove ); + dlg.exec(); +} + +void View::slotInsertCellCopy() +{ + if ( !d->activeSheet ) + return; + + if ( !d->activeSheet->testAreaPasteInsert() ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->paste( d->selection->lastRange(), true, + Paste::Normal, Paste::OverWrite, true ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } + else + { + PasteInsertDialog dlg( this, "Remove", d->selection->selection() ); + dlg.exec(); + } + + if ( d->activeSheet->getAutoCalc() ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->recalc(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } + updateEditWidget(); +} + +void View::setAreaName() +{ + AreaDialog dlg( this, "Area Name",TQPoint(d->canvas->markerColumn(), d->canvas->markerRow()) ); + dlg.exec(); +} + +void View::showAreaName() +{ + reference dlg( this, "Show Area" ); + dlg.exec(); +} + +void View::resizeRow() +{ + if (!activeSheet()) return; + + if ( d->selection->isColumnSelected() ) + KMessageBox::error( this, i18n("Area is too large.")); + else + { + ResizeRow dlg( this ); + dlg.exec(); + } +} + +void View::resizeColumn() +{ + if (!activeSheet()) return; + + + if ( d->selection->isRowSelected() ) + KMessageBox::error( this, i18n( "Area is too large." ) ); + else + { + ResizeColumn dlg( this ); + dlg.exec(); + } +} + +void View::equalizeRow() +{ + if (!activeSheet()) return; + + if ( d->selection->isColumnSelected() ) + KMessageBox::error( this, i18n( "Area is too large." ) ); + else + { + doc()->emitBeginOperation( false ); + canvasWidget()->equalizeRow(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::equalizeColumn() +{ + if (!activeSheet()) + return; + + if ( d->selection->isRowSelected() ) + KMessageBox::error( this, i18n( "Area is too large." ) ); + else + { + doc()->emitBeginOperation( false ); + canvasWidget()->equalizeColumn(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + + +void View::layoutDlg() +{ + if (!activeSheet()) + return; + + CellFormatDialog dlg( this, d->activeSheet ); +} + +void View::extraProperties() +{ + if (!activeSheet()) + return; + //d->canvas->setToolEditMode( TEM_MOUSE ); + + d->m_propertyEditor = new PropertyEditor( this, "KPrPropertyEditor", d->activeSheet, doc() ); + d->m_propertyEditor->setCaption( i18n( "Properties" ) ); + + connect( d->m_propertyEditor, TQT_SIGNAL( propertiesOk() ), this, TQT_SLOT( propertiesOk() ) ); + d->m_propertyEditor->exec(); + disconnect( d->m_propertyEditor, TQT_SIGNAL( propertiesOk() ), this, TQT_SLOT( propertiesOk() ) ); + + delete d->m_propertyEditor; + d->m_propertyEditor = 0; +} + +void View::propertiesOk() +{ + KCommand *cmd = d->m_propertyEditor->getCommand(); + + if ( cmd ) + { + cmd->execute(); + doc()->addCommand( cmd ); + } +} + +void View::styleDialog() +{ + StyleDlg dlg( this, doc()->styleManager() ); + dlg.exec(); + + d->actions->selectStyle->setItems( doc()->styleManager()->styleNames() ); + if ( d->activeSheet ) + { + d->activeSheet->setLayoutDirtyFlag(); + d->activeSheet->setRegionPaintDirty( d->activeSheet->visibleRect( d->canvas ) ); + } + if ( d->canvas ) + d->canvas->repaint(); +} + +void View::paperLayoutDlg() +{ + if ( d->canvas->editor() ) + { + d->canvas->deleteEditor( true ); // save changes + } + SheetPrint* print = d->activeSheet->print(); + + KoPageLayout pl; + pl.format = print->paperFormat(); + pl.orientation = print->orientation(); + + pl.ptWidth = MM_TO_POINT( print->paperWidth() ); + pl.ptHeight = MM_TO_POINT( print->paperHeight() ); + pl.ptLeft = MM_TO_POINT( print->leftBorder() ); + pl.ptRight = MM_TO_POINT( print->rightBorder() ); + pl.ptTop = MM_TO_POINT( print->topBorder() ); + pl.ptBottom = MM_TO_POINT( print->bottomBorder() ); + + KoHeadFoot hf; + hf.headLeft = print->localizeHeadFootLine( print->headLeft() ); + hf.headRight = print->localizeHeadFootLine( print->headRight() ); + hf.headMid = print->localizeHeadFootLine( print->headMid() ); + hf.footLeft = print->localizeHeadFootLine( print->footLeft() ); + hf.footRight = print->localizeHeadFootLine( print->footRight() ); + hf.footMid = print->localizeHeadFootLine( print->footMid() ); + + KoUnit::Unit unit = doc()->unit(); + + PaperLayout * dlg + = new PaperLayout( this, "PageLayout", pl, hf, + FORMAT_AND_BORDERS | HEADER_AND_FOOTER, + unit, d->activeSheet, this ); + dlg->show(); + // dlg destroys itself +} + +void View::definePrintRange() +{ + d->activeSheet->print()->definePrintRange( selectionInfo() ); +} + +void View::resetPrintRange() +{ + d->activeSheet->print()->resetPrintRange(); +} + +void View::wrapText( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->setSelectionMultiRow( selectionInfo(), b ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::alignLeft( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlign( selectionInfo(), + Format::Undefined ); + else + d->activeSheet->setSelectionAlign( selectionInfo(), + Format::Left ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::alignRight( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlign( selectionInfo(), Format::Undefined ); + else + d->activeSheet->setSelectionAlign( selectionInfo(), Format::Right ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::alignCenter( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlign( selectionInfo(), Format::Undefined ); + else + d->activeSheet->setSelectionAlign( selectionInfo(), Format::Center ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::alignTop( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::UndefinedY ); + else + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::Top ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::alignBottom( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::UndefinedY ); + else + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::Bottom ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::alignMiddle( bool b ) +{ + if ( d->toolbarLock ) + return; + + if ( d->activeSheet != 0L ) + { + doc()->emitBeginOperation( false ); + if ( !b ) + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::UndefinedY ); + else + d->activeSheet->setSelectionAlignY( selectionInfo(), Format::Middle ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::moneyFormat(bool b) +{ + if ( d->toolbarLock ) + return; + + doc()->emitBeginOperation( false ); + if ( d->activeSheet != 0L ) + d->activeSheet->setSelectionMoneyFormat( selectionInfo(), b ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +void View::createStyleFromCell() +{ + if ( !d->activeSheet ) + return; + + TQPoint p( d->selection->selection().topLeft() ); + Cell * cell = d->activeSheet->nonDefaultCell( p.x(), p.y() ); + + bool ok = false; + TQString styleName( "" ); + + while( true ) + { + styleName = KInputDialog::getText( i18n( "Create Style From Cell" ), + i18n( "Enter name:" ), styleName, &ok, this ); + + if ( !ok ) // User pushed an OK button. + return; + + styleName = styleName.stripWhiteSpace(); + + if ( styleName.length() < 1 ) + { + KNotifyClient::beep(); + KMessageBox::sorry( this, i18n( "The style name cannot be empty." ) ); + continue; + } + + if ( doc()->styleManager()->style( styleName ) != 0 ) + { + KNotifyClient::beep(); + KMessageBox::sorry( this, i18n( "A style with this name already exists." ) ); + continue; + } + break; + } + + CustomStyle * style = new CustomStyle( cell->format()->style(), styleName ); + + doc()->styleManager()->m_styles[ styleName ] = style; + cell->format()->setStyle( style ); + TQStringList lst( d->actions->selectStyle->items() ); + lst.push_back( styleName ); + d->actions->selectStyle->setItems( lst ); +} + +void View::styleSelected( const TQString & style ) +{ + if (d->activeSheet ) + { + Style * s = doc()->styleManager()->style( style ); + + if ( s ) + { + doc()->emitBeginOperation(false); + d->activeSheet->setSelectionStyle( selectionInfo(), s ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } + } +} + +void View::precisionPlus() +{ + setSelectionPrecision( 1 ); +} + +void View::precisionMinus() +{ + setSelectionPrecision( -1 ); +} + +void View::setSelectionPrecision( int delta ) +{ + if ( d->activeSheet != NULL ) + { + doc()->emitBeginOperation( false ); + d->activeSheet->setSelectionPrecision( selectionInfo(), delta ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::percent( bool b ) +{ + if ( d->toolbarLock ) + return; + + doc()->emitBeginOperation( false ); + if ( d->activeSheet != 0L ) + d->activeSheet->setSelectionPercent( selectionInfo() ,b ); + updateEditWidget(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + + +void View::insertObject() +{ + if (!activeSheet()) + return; + + doc()->emitBeginOperation( false ); + KoDocumentEntry e = d->actions->insertPart->documentEntry();//KoPartSelectDia::selectPart( d->canvas ); + if ( e.isEmpty() ) + { + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + return; + } + + //Don't start handles more than once + delete d->insertHandler; + + d->insertHandler = new InsertPartHandler( this, d->canvas, e ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::insertChart() +{ + if (!activeSheet()) + return; + + if ( d->selection->isColumnOrRowSelected() ) + { + KMessageBox::error( this, i18n("Area too large.")); + return; + } + TQValueList<KoDocumentEntry> vec = KoDocumentEntry::query( true, "'KOfficeChart' in ServiceTypes" ); + if ( vec.isEmpty() ) + { + KMessageBox::error( this, i18n("No charting component registered.") ); + return; + } + + //Don't start handles more than once + delete d->insertHandler; + + doc()->emitBeginOperation( false ); + + d->insertHandler = new InsertChartHandler( this, d->canvas, vec[0] ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + + + +/* + // TODO Use KoView setScaling/xScaling/yScaling instead +void View::zoomMinus() +{ + if ( m_fZoom <= 0.25 ) + return; + + m_fZoom -= 0.25; + + if ( d->activeSheet != 0L ) + d->activeSheet->setLayoutDirtyFlag(); + + d->canvas->repaint(); + d->vBorderWidget->repaint(); + d->hBorderWidget->repaint(); +} + +void View::zoomPlus() +{ + if ( m_fZoom >= 3 ) + return; + + m_fZoom += 0.25; + + if ( d->activeSheet != 0L ) + d->activeSheet->setLayoutDirtyFlag(); + + d->canvas->repaint(); + d->vBorderWidget->repaint(); + d->hBorderWidget->repaint(); +} +*/ + +void View::removeSheet() +{ + if ( doc()->map()->count() <= 1 || ( doc()->map()->visibleSheets().count() <= 1 ) ) + { + KNotifyClient::beep(); + KMessageBox::sorry( this, i18n("You cannot delete the only sheet."), i18n("Remove Sheet") ); // FIXME bad english? no english! + return; + } + KNotifyClient::beep(); + int ret = KMessageBox::warningContinueCancel( this, i18n( "You are about to remove the active sheet.\nDo you want to continue?" ), + i18n( "Remove Sheet" ),KGuiItem(i18n("&Delete"),"edit-delete") ); + + if ( ret == KMessageBox::Continue ) + { + doc()->emitBeginOperation( false ); + if ( d->canvas->editor() ) + { + d->canvas->deleteEditor( false ); + } + doc()->setModified( true ); + Sheet * tbl = activeSheet(); + KCommand* command = new RemoveSheetCommand( tbl ); + doc()->addCommand( command ); + command->execute(); + + +#if 0 + UndoRemoveSheet * undo = new UndoRemoveSheet( doc(), tbl ); + doc()->addCommand( undo ); + tbl->doc()->map()->takeSheet( tbl ); + doc()->takeSheet( tbl ); +#endif + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + + +void View::slotRename() +{ + + Sheet * sheet = activeSheet(); + + if( sheet->isProtected() ) + { + KMessageBox::error( 0, i18n ( "You cannot change a protected sheet." ) ); + return; + } + + bool ok; + TQString activeName = sheet->sheetName(); + TQString newName = KInputDialog::getText( i18n("Rename Sheet"),i18n("Enter name:"), activeName, &ok, this ); + + if( !ok ) return; + + while (!util_validateSheetName(newName)) + { + KNotifyClient::beep(); + KMessageBox::information( this, i18n("Sheet name contains illegal characters. Only numbers and letters are allowed."), + i18n("Change Sheet Name") ); + + newName = newName.simplifyWhiteSpace(); + int n = newName.find('-'); + if ( n > -1 ) newName[n] = '_'; + n = newName.find('!'); + if ( n > -1 ) newName[n] = '_'; + n = newName.find('$'); + if ( n > -1 ) newName[n] = '_'; + + newName = KInputDialog::getText( i18n("Rename Sheet"),i18n("Enter name:"), newName, &ok, this ); + + if ( !ok ) return; + } + + if ( (newName.stripWhiteSpace()).isEmpty() ) // Sheet name is empty. + { + KNotifyClient::beep(); + KMessageBox::information( this, i18n("Sheet name cannot be empty."), i18n("Change Sheet Name") ); + // Recursion + slotRename(); + } + else if ( newName != activeName ) // Sheet name changed. + { + // Is the name already used + if ( doc()->map()->findSheet( newName ) ) + { + KNotifyClient::beep(); + KMessageBox::information( this, i18n("This name is already used."), i18n("Change Sheet Name") ); + // Recursion + slotRename(); + return; + } + + KCommand* command = new RenameSheetCommand( sheet, newName ); + doc()->addCommand( command ); + command->execute(); + + //sheet->setSheetName( newName ); + + doc()->emitBeginOperation(false); + updateEditWidget(); + doc()->setModified( true ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + } +} + +void View::setText (const TQString & _text, bool array) +{ + if ( d->activeSheet == 0L ) + return; + + if (array) { + // array version + d->activeSheet->setArrayFormula (d->selection, _text); + } + else + { + // non-array version + int x = d->canvas->markerColumn(); + int y = d->canvas->markerRow(); + + d->activeSheet->setText( y, x, _text ); + + Cell * cell = d->activeSheet->cellAt( x, y ); + if ( cell->value().isString() && !_text.isEmpty() && !_text.at(0).isDigit() && !cell->isFormula() ) + doc()->addStringCompletion( _text ); + } +} + +//------------------------------------------------ +// +// Document signals +// +//------------------------------------------------ + +void View::slotAddSheet( Sheet *_sheet ) +{ + addSheet( _sheet ); +} + +void View::slotRefreshView() +{ + refreshView(); + d->canvas->repaint(); + d->vBorderWidget->repaint(); + d->hBorderWidget->repaint(); +} + +void View::slotUpdateView( Sheet *_sheet ) +{ + // Do we display this sheet ? + if ( ( !activeSheet() ) || ( _sheet != d->activeSheet ) ) + return; + + d->activeSheet->setRegionPaintDirty( d->activeSheet->visibleRect( d->canvas ) ); + doc()->emitEndOperation(); +} + +void View::slotUpdateView( Sheet * _sheet, const Region& region ) +{ + // tqDebug("void View::slotUpdateView( Sheet *_sheet, const TQRect& %i %i|%i %i )\n",_rect.left(),_rect.top(),_rect.right(),_rect.bottom()); + + // Do we display this sheet ? + if ( _sheet != d->activeSheet ) + return; + + // doc()->emitBeginOperation( false ); + d->activeSheet->setRegionPaintDirty( region ); + doc()->emitEndOperation( region ); +} + +void View::slotUpdateView( EmbeddedObject *obj ) +{ + d->canvas->repaintObject( obj ); +} + +void View::slotUpdateHBorder( Sheet * _sheet ) +{ + // kdDebug(36001)<<"void View::slotUpdateHBorder( Sheet *_sheet )\n"; + + // Do we display this sheet ? + if ( _sheet != d->activeSheet ) + return; + + doc()->emitBeginOperation(false); + d->hBorderWidget->update(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::slotUpdateVBorder( Sheet *_sheet ) +{ + // kdDebug("void View::slotUpdateVBorder( Sheet *_sheet )\n"; + + // Do we display this sheet ? + if ( _sheet != d->activeSheet ) + return; + + doc()->emitBeginOperation( false ); + d->vBorderWidget->update(); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::slotChangeSelection(const KSpread::Region& changedRegion) +{ +// kdDebug() << *selectionInfo() << endl; + + if (!changedRegion.isValid()) + { + return; + } + + doc()->emitBeginOperation( false ); + + bool colSelected = d->selection->isColumnSelected(); + bool rowSelected = d->selection->isRowSelected(); + if (d->activeSheet && !d->activeSheet->isProtected()) + { + // Activate or deactivate some actions. + d->actions->insertRow->setEnabled( !colSelected ); + d->actions->deleteRow->setEnabled( !colSelected ); + d->actions->resizeRow->setEnabled( !colSelected ); + d->actions->equalizeRow->setEnabled( !colSelected ); + d->actions->hideRow->setEnabled( !colSelected ); + d->actions->validity->setEnabled( !colSelected && !rowSelected); + d->actions->conditional->setEnabled( !colSelected && !rowSelected); + d->actions->insertColumn->setEnabled( !rowSelected ); + d->actions->deleteColumn->setEnabled( !rowSelected ); + d->actions->resizeColumn->setEnabled( !rowSelected ); + d->actions->equalizeColumn->setEnabled( !rowSelected ); + d->actions->hideColumn->setEnabled( !rowSelected ); + d->actions->textToColumns->setEnabled( !rowSelected ); + + bool simpleSelection = d->selection->isSingular() || colSelected || rowSelected; + d->actions->autoFormat->setEnabled( !simpleSelection ); + d->actions->sort->setEnabled( !simpleSelection ); + d->actions->mergeCell->setEnabled( !simpleSelection ); + d->actions->mergeCellHorizontal->setEnabled( !simpleSelection ); + d->actions->mergeCellVertical->setEnabled( !simpleSelection ); + d->actions->fillRight->setEnabled( !simpleSelection ); + d->actions->fillUp->setEnabled( !simpleSelection ); + d->actions->fillDown->setEnabled( !simpleSelection ); + d->actions->fillLeft->setEnabled( !simpleSelection ); + d->actions->sortDec->setEnabled( !simpleSelection ); + d->actions->sortInc->setEnabled( !simpleSelection); + d->actions->createStyle->setEnabled( simpleSelection ); // just from one cell + + bool contiguousSelection = d->selection->isContiguous(); + d->actions->subTotals->setEnabled(contiguousSelection); + } + d->actions->selectStyle->setCurrentItem( -1 ); + // delayed recalculation of the operation shown in the status bar + d->statusBarOpTimer.start(250, true); + // Send some event around. This is read for example + // by the calculator plugin. +// SelectionChanged ev(*selectionInfo(), activeSheet()->name()); +// TQApplication::sendEvent( this, &ev ); + + d->canvas->setSelectionChangePaintDirty( d->activeSheet, changedRegion ); + d->vBorderWidget->update(); + d->hBorderWidget->update(); + + if (colSelected || rowSelected) + { + doc()->emitEndOperation(/* *selectionInfo() */); + return; + } + + d->canvas->validateSelection(); + + //Don't scroll to the marker if there is an active embedded object, since this may cause + //the canvas to scroll so that the object isn't in the visible area. + //There is still the problem of the object no longer being visible immediately after deactivating the child + //as the sheet jumps back to the marker though. + if (!activeChild()) + d->canvas->scrollToCell(selectionInfo()->marker()); + + // Perhaps the user is entering a value in the cell. + // In this case we may not touch the EditWidget + if ( !d->canvas->editor() && !d->canvas->chooseMode() ) + { + updateEditWidgetOnPress(); + } + d->canvas->updatePosWidget(); + + doc()->emitEndOperation(/* *selectionInfo() */); +} + +void View::slotChangeChoice(const KSpread::Region& changedRegion) +{ + if (!changedRegion.isValid()) + { + return; + } + doc()->emitBeginOperation( false ); + d->canvas->updateEditor(); + d->canvas->setSelectionChangePaintDirty( d->activeSheet, changedRegion ); + doc()->emitEndOperation( *choice() ); + kdDebug() << "Choice: " << *choice() << endl; +} + +void View::slotScrollChoice( const KSpread::Region& changedRegion ) +{ + if ( !changedRegion.isValid() ) + return; + d->canvas->scrollToCell( choice()->marker() ); +} + +void View::calcStatusBarOp() +{ + Sheet * sheet = activeSheet(); + ValueCalc* calc = d->doc->calc(); + Value val; + TQRect tmpRect(d->selection->selection()); + MethodOfCalc tmpMethod = doc()->getTypeOfCalc(); + if ( tmpMethod != NoneCalc ) + { + + Value range = sheet->valueRange (tmpRect.left(), tmpRect.top(), + tmpRect.right(), tmpRect.bottom()); + switch (tmpMethod) + { + case SumOfNumber: + val = calc->sum (range); + break; + case Average: + val = calc->avg (range); + break; + case Min: + val = calc->min (range); + break; + case Max: + val = calc->max (range); + break; + case CountA: + val = Value (calc->count (range)); + break; + case Count: + val = Value (calc->count (range, false)); + case NoneCalc: + break; + default: + break; + } + + } + + TQString res = d->doc->converter()->asString (val).asString (); + TQString tmp; + switch(tmpMethod ) + { + case SumOfNumber: + tmp = i18n("Sum: ") + res; + break; + case Average: + tmp = i18n("Average: ") + res; + break; + case Min: + tmp = i18n("Min: ") + res; + break; + case Max: + tmp = i18n("Max: ") + res; + break; + case Count: + tmp = i18n("Count: ") + res; + break; + case CountA: + tmp = i18n("CountA: ") + res; + break; + case NoneCalc: + tmp = ""; + break; + } + + //doc()->emitBeginOperation(); + if ( d->calcLabel ) + d->calcLabel->setText(TQString(" ") + tmp + ' '); + //doc()->emitEndOperation(); +} + +void View::statusBarClicked(int _id) +{ + if ( !koDocument()->isReadWrite() || !factory() ) + return; + if ( _id == 0 ) //menu calc + { + TQPoint mousepos = TQCursor::pos(); + ((TQPopupMenu*)factory()->container( "calc_popup" , this ) )->popup( mousepos ); + } +} + +void View::menuCalc( bool ) +{ + doc()->emitBeginOperation(false); + if ( d->actions->calcMin->isChecked() ) + { + doc()->setTypeOfCalc( Min ); + } + else if ( d->actions->calcMax->isChecked() ) + { + doc()->setTypeOfCalc( Max ); + } + else if ( d->actions->calcCount->isChecked() ) + { + doc()->setTypeOfCalc( Count ); + } + else if ( d->actions->calcAverage->isChecked() ) + { + doc()->setTypeOfCalc( Average ); + } + else if ( d->actions->calcSum->isChecked() ) + { + doc()->setTypeOfCalc( SumOfNumber ); + } + else if ( d->actions->calcCountA->isChecked() ) + { + doc()->setTypeOfCalc( CountA ); + } + else if ( d->actions->calcNone->isChecked() ) + doc()->setTypeOfCalc( NoneCalc ); + + calcStatusBarOp(); + + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + + +TQWMatrix View::matrix() const +{ + TQWMatrix m; + m.scale( d->doc->zoomedResolutionX(), + d->doc->zoomedResolutionY() ); + m.translate( - d->canvas->xOffset(), - d->canvas->yOffset() ); + return m; +} + +void View::transformPart() +{ + Q_ASSERT( selectedChild() ); + + if ( d->transformToolBox.isNull() ) + { + d->transformToolBox = new KoTransformToolBox( selectedChild(), topLevelWidget() ); + d->transformToolBox->show(); + + d->transformToolBox->setDocumentChild( selectedChild() ); + } + else + { + d->transformToolBox->show(); + d->transformToolBox->raise(); + } +} + +void View::slotChildSelected( KoDocumentChild* /*ch*/ ) +{ +// if ( d->activeSheet && !d->activeSheet->isProtected() ) +// { +// d->actions->transform->setEnabled( true ); +// +// if ( !d->transformToolBox.isNull() ) +// { +// d->transformToolBox->setEnabled( true ); +// d->transformToolBox->setDocumentChild( ch ); +// } +// } + + + doc()->emitBeginOperation( false ); + d->activeSheet->setRegionPaintDirty(TQRect(TQPoint(0,0), TQPoint(KS_colMax, KS_rowMax))); + + doc()->emitEndOperation(); + paintUpdates(); +} + +void View::slotChildUnselected( KoDocumentChild* ) +{ +// if ( d->activeSheet && !d->activeSheet->isProtected() ) +// { +// d->actions->transform->setEnabled( false ); +// +// if ( !d->transformToolBox.isNull() ) +// { +// d->transformToolBox->setEnabled( false ); +// } +// deleteEditor( true ); +// } + + + doc()->emitBeginOperation( false ); + d->activeSheet->setRegionPaintDirty(TQRect(TQPoint(0,0), TQPoint(KS_colMax, KS_rowMax))); + doc()->emitEndOperation(); + paintUpdates(); +} + + +void View::deleteEditor( bool saveChanges ) +{ + doc()->emitBeginOperation( false ); + d->canvas->deleteEditor( saveChanges ); + + markSelectionAsDirty(); + doc()->emitEndOperation(); +} + +DCOPObject * View::dcopObject() +{ + if ( !d->dcop ) + d->dcop = new ViewIface( this ); + + return d->dcop; +} + +TQWidget * View::canvas() const +{ + return canvasWidget(); +} + +int View::canvasXOffset() const +{ + if (!d->activeSheet) + return 0; + + double zoomedResX = d->activeSheet->doc()->zoomedResolutionX(); + return int( canvasWidget()->xOffset() * zoomedResX ); +} + +int View::canvasYOffset() const +{ + if (!d->activeSheet) + return 0; + + double zoomedResY = d->activeSheet->doc()->zoomedResolutionY(); + return int( canvasWidget()->yOffset() * zoomedResY ); +} + + +void View::guiActivateEvent( KParts::GUIActivateEvent *ev ) +{ + if ( d->activeSheet ) + { + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); + + if ( ev->activated() ) + { + if ( d->calcLabel ) + calcStatusBarOp(); + } + else + { + /*if (d->calcLabel) + { + disconnect(d->calcLabel,TQT_SIGNAL(pressed( int )),this,TQT_SLOT(statusBarClicked(int))); + }*/ + } + } + + KoView::guiActivateEvent( ev ); +} + +void View::popupTabBarMenu( const TQPoint & _point ) +{ + if ( !koDocument()->isReadWrite() || !factory() ) + return; + if ( d->tabBar ) + { + bool state = ( doc()->map()->visibleSheets().count() > 1 ); + if ( d->activeSheet && d->activeSheet->isProtected() ) + { + d->actions->removeSheet->setEnabled( false ); + d->actions->hideSheet->setEnabled( false ); + d->actions->showSheet->setEnabled( false ); + } + else + { + d->actions->removeSheet->setEnabled( state); + d->actions->hideSheet->setEnabled( state ); + d->actions->showSheet->setEnabled( doc()->map()->hiddenSheets().count()>0 ); + } + if ( !doc() || !doc()->map() || doc()->map()->isProtected() ) + { + d->actions->insertSheet->setEnabled( false ); + d->actions->renameSheet->setEnabled( false ); + d->actions->showSheet->setEnabled( false ); + d->actions->hideSheet->setEnabled( false ); + d->actions->removeSheet->setEnabled( false ); + } + static_cast<TQPopupMenu*>(factory()->container("menupage_popup",this))->popup(_point); + } +} + +void View::updateBorderButton() +{ + // doc()->emitBeginOperation( false ); + if ( d->activeSheet ) + d->actions->showPageBorders->setChecked( d->activeSheet->isShowPageBorders() ); + // doc()->emitEndOperation(); +} + +void View::removeSheet( Sheet *_t ) +{ + doc()->emitBeginOperation(false); + TQString m_tablName=_t->sheetName(); + d->tabBar->removeTab( m_tablName ); + setActiveSheet( doc()->map()->findSheet( doc()->map()->visibleSheets().first() )); + + bool state = doc()->map()->visibleSheets().count() > 1; + d->actions->removeSheet->setEnabled( state ); + d->actions->hideSheet->setEnabled( state ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::insertSheet( Sheet* sheet ) +{ + doc()->emitBeginOperation( false ); + TQString tabName = sheet->sheetName(); + if ( !sheet->isHidden() ) + { + d->tabBar->addTab( tabName ); + } + + bool state = ( doc()->map()->visibleSheets().count() > 1 ); + d->actions->removeSheet->setEnabled( state ); + d->actions->hideSheet->setEnabled( state ); + doc()->emitEndOperation( sheet->visibleRect( d->canvas ) ); +} + +TQColor View::borderColor() const +{ + return d->actions->borderColor->color(); +} + +void View::updateShowSheetMenu() +{ + doc()->emitBeginOperation( false ); + if ( d->activeSheet->isProtected() ) + d->actions->showSheet->setEnabled( false ); + else + d->actions->showSheet->setEnabled( doc()->map()->hiddenSheets().count() > 0 ); + doc()->emitEndOperation( d->activeSheet->visibleRect( d->canvas ) ); +} + +void View::closeEditor() +{ + if ( d->activeSheet ) { // #45822 + doc()->emitBeginOperation( false ); + d->canvas->closeEditor(); + + markSelectionAsDirty(); + doc()->emitEndOperation(); + } +} + +void View::markSelectionAsDirty() +{ + if (!d->activeSheet) + return; + + d->activeSheet->setRegionPaintDirty( *selectionInfo() ); +} + +void View::paintUpdates() +{ + /* don't do any begin/end operation here -- this is what is called at an + endOperation + */ + d->canvas->paintUpdates(); +} + +void View::commandExecuted() +{ + updateEditWidget(); + calcStatusBarOp(); +} + +void View::initialiseMarkerFromSheet( Sheet *_sheet, const TQPoint &point ) +{ + d->savedMarkers.replace( _sheet, point); +} + +TQPoint View::markerFromSheet( Sheet* sheet ) const +{ + TQMapIterator<Sheet*, TQPoint> it = d->savedMarkers.find(sheet); + TQPoint newMarker = (it == d->savedMarkers.end()) ? TQPoint(1,1) : *it; + return newMarker; +} + +KoPoint View::offsetFromSheet( Sheet* sheet ) const +{ + TQMapIterator<Sheet*, KoPoint> it = d->savedOffsets.find(sheet); + KoPoint offset = (it == d->savedOffsets.end()) ? KoPoint() : *it; + return offset; +} + +void View::saveCurrentSheetSelection() +{ + /* save the current selection on this sheet */ + if (d->activeSheet != NULL) + { + d->savedAnchors.replace(d->activeSheet, d->selection->anchor()); + kdDebug() << " Current scrollbar vert value: " << d->canvas->vertScrollBar()->value() << endl; + kdDebug() << "Saving marker pos: " << d->selection->marker() << endl; + d->savedMarkers.replace(d->activeSheet, d->selection->marker()); + d->savedOffsets.replace(d->activeSheet, KoPoint(d->canvas->xOffset(), + d->canvas->yOffset())); + } +} + +void View::handleDamages( const TQValueList<Damage*>& damages ) +{ + TQValueList<Damage*>::ConstIterator it; + for( it = damages.begin(); it != damages.end(); ++it ) + { + Damage* damage = *it; + if( !damage ) continue; + + if( damage->type() == Damage::Cell ) + { + CellDamage* cd = static_cast<CellDamage*>( damage ); + Cell* damagedCell = cd->cell(); + Sheet* damagedSheet = damagedCell->sheet(); + TQRect drect( damagedCell->column(), damagedCell->row(), 1, 1 ); + damagedSheet->setRegionPaintDirty( drect ); + paintUpdates(); + } + + if( damage->type() == Damage::Sheet ) + { + SheetDamage* sd = static_cast<SheetDamage*>( damage ); + Sheet* damagedSheet = sd->sheet(); + + if( sd->action() == SheetDamage::PropertiesChanged ) + { + CellBinding * b = 0; + for ( b = damagedSheet->firstCellBinding(); b != 0; + b = damagedSheet->nextCellBinding() ) + b->cellChanged( 0 ); + + d->activeSheet->setRegionPaintDirty( TQRect(TQPoint(0,0), + TQPoint(KS_colMax, KS_rowMax))); + + paintUpdates(); + refreshView(); + } + + } + + } +} + +void View::runInternalTests() +{ + // run various tests, only for developers + KSpread::TestRunner* runner = new KSpread::TestRunner(); + runner->exec(); + delete runner; +} + +void View::runInspector() +{ + // useful to inspect objects + if(!d->activeSheet) return; + Cell * cell = d->activeSheet->cellAt( d->selection->marker() ); + KSpread::Inspector* ins = new KSpread::Inspector( cell ); + ins->exec(); + delete ins; +} + +TQColor View::highlightColor() +{ + return TQApplication::palette().active().highlight().light( 175 ); +} + +} // namespace KSpread + +#include "kspread_view.moc" |