* commit 'ooo/DEV300_m101': (76 commits) masterfix DEV300: #i10000# usage of L10N build_type removetooltypes01: Fix build problems after rebase to DEV300m99 in basctl, cui, reportdesign, sw hr75: #i116747#: remove obsolete copyright notices gnumake3: remove comphelper version; fix including extract.hxx removetooltypes01: #i112600# Replace missing tools types replacement removetooltypes01: #i112600# remove tooltypes from reportdesign removetooltypes01: #i112600# remove tooltypes from dbaccess undoapi: don't use deprecated JUnit API, this seems to fail now (but didn't before the rebase) undoapi: those two classes do not belong into JAVATESTFILES, but JAVAFILES only undoapi: (I|Sfx)UndoManager now working with size_t instead of USHORT gridsort: give the UnoControl(Model/Base) classes a ctor taking a service factory, so we have access to the factory which created us, and don't need to resort to the process'es service factory dba34b: #109956# notify column value in correct order dba34b: #i114309# set default values for bit boolean and reset when we are on the insertrow undoapi: assert unknown slots in ImplInvalidateFeature dba34b: #i110907# check if design handle event dba34b: #i109956# notify column values when row is refreshed dba34b: #i115753# add test again undoapi: renamed Undo.* to RptUndo.*, to not confuse a certain IDE with different same-named files in the source tree ... undoapi: migrated report designer to use an own, model-bound UndoManager, instead of the UndoManager formerly bound to the controller undoapi: split OSingleDocumentController into DBSubComponentController (which the report design's controller will be derived from) and the still-so-named OSingleDocumentController. Module reportdesign does not compile with this change, this is yet to come. ... Conflicts: dbaccess/inc/IEnvironment.hxx dbaccess/inc/dataview.hxx dbaccess/qa/complex/dbaccess/RowSet.java dbaccess/source/core/api/CacheSet.cxx dbaccess/source/core/api/KeySet.hxx dbaccess/source/core/api/OptimisticSet.hxx dbaccess/source/core/api/RowSet.cxx dbaccess/source/core/api/RowSetCache.cxx dbaccess/source/ext/adabas/Acomponentmodule.cxx dbaccess/source/ext/adabas/Aservices.cxx dbaccess/source/filter/migration/cfgimport.cxx dbaccess/source/filter/migration/cfgimport.hxx dbaccess/source/filter/migration/cfgservices.cxx dbaccess/source/filter/migration/makefile.mk dbaccess/source/inc/cfg_reghelper.hxx dbaccess/source/sdbtools/misc/sdbt_services.cxx dbaccess/source/shared/cfg_reghelper.cxx dbaccess/source/shared/cfgstrings.cxx dbaccess/source/shared/registrationhelper.cxx dbaccess/source/ui/app/AppController.cxx dbaccess/source/ui/app/AppDetailPageHelper.cxx dbaccess/source/ui/app/AppDetailPageHelper.hxx dbaccess/source/ui/app/AppDetailView.cxx dbaccess/source/ui/app/AppIconControl.cxx dbaccess/source/ui/app/AppSwapWindow.cxx dbaccess/source/ui/browser/brwctrlr.cxx dbaccess/source/ui/browser/dataview.cxx dbaccess/source/ui/browser/unodatbr.cxx dbaccess/source/ui/control/dbtreelistbox.cxx dbaccess/source/ui/control/opendoccontrols.cxx dbaccess/source/ui/control/tabletree.cxx dbaccess/source/ui/dlg/ConnectionHelper.cxx dbaccess/source/ui/dlg/ConnectionPage.src dbaccess/source/ui/dlg/ExtensionNotPresent.cxx dbaccess/source/ui/dlg/ExtensionNotPresent.hrc dbaccess/source/ui/dlg/ExtensionNotPresent.src dbaccess/source/ui/dlg/TablesSingleDlg.cxx dbaccess/source/ui/dlg/adodatalinks.hxx dbaccess/source/ui/dlg/dbadmin2.src dbaccess/source/ui/dlg/dbadminsetup.src dbaccess/source/ui/dlg/dlgattr.cxx dbaccess/source/ui/dlg/dlgsize.src dbaccess/source/ui/dlg/makefile.mk dbaccess/source/ui/dlg/sqlmessage.cxx dbaccess/source/ui/inc/ExtensionNotPresent.hxx dbaccess/source/ui/inc/TokenWriter.hxx dbaccess/source/ui/inc/imageprovider.hxx dbaccess/source/ui/misc/DExport.cxx dbaccess/source/ui/misc/HtmlReader.cxx dbaccess/source/ui/misc/RowSetDrop.cxx dbaccess/source/ui/misc/RtfReader.cxx dbaccess/source/ui/misc/TokenWriter.cxx dbaccess/source/ui/misc/imageprovider.cxx dbaccess/source/ui/misc/linkeddocuments.cxx dbaccess/source/ui/misc/singledoccontroller.cxx dbaccess/source/ui/querydesign/ConnectionData.hxx dbaccess/source/ui/querydesign/JoinTableView.cxx dbaccess/source/ui/querydesign/SelectionBrowseBox.cxx dbaccess/source/ui/querydesign/TableConnectionData.cxx dbaccess/source/ui/querydesign/TableWindowListBox.cxx dbaccess/source/ui/relationdesign/RelationController.cxx dbaccess/source/ui/relationdesign/RelationTableView.cxx dbaccess/source/ui/tabledesign/table.src reportdesign/inc/RptPage.hxx reportdesign/qa/complex/reportdesign/ReportDesignerTest.java reportdesign/source/core/api/ReportDefinition.cxx reportdesign/source/core/sdr/ReportUndoFactory.cxx reportdesign/source/core/sdr/UndoEnv.cxx reportdesign/source/filter/xml/xmlservices.cxx reportdesign/source/ui/dlg/GroupsSorting.cxx reportdesign/source/ui/dlg/Navigator.cxx reportdesign/source/ui/inspection/metadata.cxx reportdesign/source/ui/misc/RptUndo.cxx reportdesign/source/ui/misc/UITools.cxx reportdesign/source/ui/misc/rptuiservices.cxx reportdesign/source/ui/report/DesignView.cxx reportdesign/source/ui/report/FixedTextColor.cxx reportdesign/source/ui/report/ReportController.cxx reportdesign/source/ui/report/ReportSection.cxx reportdesign/source/ui/report/SectionView.cxx reportdesign/source/ui/report/SectionWindow.cxx reportdesign/source/ui/report/StartMarker.cxx reportdesign/source/ui/report/ViewsWindow.cxx reportdesign/source/ui/report/dlgedfunc.cxx reportdesign/source/ui/report/report.src
348 lines
17 KiB
C++
348 lines
17 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* This file is part of OpenOffice.org.
|
|
*
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
* only, as published by the Free Software Foundation.
|
|
*
|
|
* OpenOffice.org 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 Lesser General Public License version 3 for more details
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
* <http://www.openoffice.org/license.html>
|
|
* for a copy of the LGPLv3 License.
|
|
*
|
|
************************************************************************/
|
|
#ifndef DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
#define DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
|
|
#include <svtools/editbrowsebox.hxx>
|
|
#include "TableFieldDescription.hxx"
|
|
#include "JoinExchange.hxx"
|
|
#include "QEnumTypes.hxx"
|
|
#include <com/sun/star/util/XNumberFormatter.hpp>
|
|
#include <tools/string.hxx>
|
|
#include <svtools/transfer.hxx>
|
|
|
|
namespace connectivity
|
|
{
|
|
class OSQLParseNode;
|
|
}
|
|
|
|
namespace dbaui
|
|
{
|
|
//==================================================================
|
|
#define SIZ_NONE 0
|
|
#define SIZ_TOP 1
|
|
#define SIZ_BOTTOM 2
|
|
#define SIZ_LEFT 4
|
|
#define SIZ_RIGHT 8
|
|
|
|
#define BROW_FIELD_ROW 0
|
|
#define BROW_COLUMNALIAS_ROW 1
|
|
#define BROW_TABLE_ROW 2
|
|
#define BROW_ORDER_ROW 3
|
|
#define BROW_VIS_ROW 4
|
|
#define BROW_FUNCTION_ROW 5
|
|
#define BROW_CRIT1_ROW 6
|
|
#define BROW_CRIT2_ROW 7
|
|
#define BROW_CRIT3_ROW 8
|
|
#define BROW_CRIT4_ROW 9
|
|
#define BROW_CRIT5_ROW 10
|
|
#define BROW_CRIT6_ROW 11
|
|
#define BROW_ROW_CNT 12
|
|
|
|
//==================================================================
|
|
class OQueryDesignView;
|
|
class OSelectionBrowseBox : public ::svt::EditBrowseBox
|
|
{
|
|
friend class OQueryDesignView;
|
|
::std::vector<bool> m_bVisibleRow; // an Pos steht die RowId
|
|
Timer m_timerInvalidate;
|
|
|
|
long m_nSeekRow;
|
|
BrowserMode m_nMode; // Merken des BrowseModes
|
|
Edit* m_pTextCell;
|
|
::svt::CheckBoxControl* m_pVisibleCell;
|
|
::svt::ComboBoxControl* m_pFieldCell;
|
|
::svt::ListBoxControl* m_pFunctionCell;
|
|
::svt::ListBoxControl* m_pTableCell;
|
|
::svt::ListBoxControl* m_pOrderCell;
|
|
|
|
OTableFieldDescRef m_pEmptyEntry; // default entry in the list may reference more than once
|
|
|
|
sal_Int32 m_nMaxColumns; // maximale Anzahl der Spalten in einem Select-Statement
|
|
|
|
String m_aFunctionStrings;
|
|
sal_uInt16 m_nVisibleCount; // Anzahl der max sichtbaren Zeilen
|
|
sal_Bool m_bOrderByUnRelated;
|
|
sal_Bool m_bGroupByUnRelated;
|
|
sal_Bool m_bStopTimer;
|
|
sal_Bool m_bWasEditing;
|
|
sal_Bool m_bDisableErrorBox;
|
|
sal_Bool m_bInUndoMode;
|
|
|
|
DECL_LINK(OnInvalidateTimer, void*);
|
|
public: OSelectionBrowseBox( Window* pParent );
|
|
~OSelectionBrowseBox();
|
|
|
|
void initialize();
|
|
OTableFieldDescRef InsertField( const OJoinExchangeData& jxdSource, sal_uInt16 _nColumnPostion = BROWSER_INVALIDID, sal_Bool bVis=sal_True, sal_Bool bActivate=sal_True );
|
|
OTableFieldDescRef InsertField( const OTableFieldDescRef& rInfo, sal_uInt16 _nColumnPostion = BROWSER_INVALIDID, sal_Bool bVis=sal_True, sal_Bool bActivate=sal_True );
|
|
void InsertColumn( OTableFieldDescRef pEntry, sal_uInt16& _nColumnPostion );
|
|
void RemoveColumn( sal_uInt16 _nColumnId );
|
|
void DeleteFields( const String& rAliasName );
|
|
|
|
bool HasFieldByAliasName(const ::rtl::OUString& rFieldName, OTableFieldDescRef& rInfo) const;
|
|
// AddGroupBy:: F"ugt ein Feld mit Funktion == Grupierung. Falls das Feld schon vorhanden ist und ein Aggregate Funktion
|
|
// benutzt, wird das Flag nicht gesetzt
|
|
void AddGroupBy( const OTableFieldDescRef& rInfo,sal_uInt32 _nCurrentPos);
|
|
void AddCondition( const OTableFieldDescRef& rInfo,
|
|
const String& rValue,
|
|
const sal_uInt16 nLevel,
|
|
bool _bAddOrOnOneLine );
|
|
void DuplicateConditionLevel( const sal_uInt16 nLevel);
|
|
void AddOrder(const OTableFieldDescRef& rInfo, const EOrderDir eDir, sal_uInt32 _nCurrentPos);
|
|
void ClearAll();
|
|
OTableFieldDescRef AppendNewCol( sal_uInt16 nCnt=1 );
|
|
sal_Bool Save();
|
|
OQueryDesignView* getDesignView();
|
|
OQueryDesignView* getDesignView() const;
|
|
sal_uInt16 FieldsCount();
|
|
|
|
void SetColWidth(sal_uInt16 nColId, long lNewWidth);
|
|
// beachtet im Gegensatz zum SetColumnWidth der Basisklasse auch eine eventuell aktive Zelle in dieser Spalte
|
|
|
|
String GetCellContents(sal_Int32 nCellIndex, sal_uInt16 nColId);
|
|
void SetCellContents(sal_Int32 nCellIndex, sal_uInt16 nColId, const String& strNewText);
|
|
// Zelleninhalt (als String formatiert) setzen/liefern
|
|
sal_Int32 GetNoneVisibleRows() const;
|
|
void SetNoneVisbleRow(long nRows);
|
|
sal_Bool IsRowVisible(sal_uInt16 _nWhich) const;
|
|
void SetRowVisible(sal_uInt16 _nWhich, sal_Bool _bVis);
|
|
|
|
void SetReadOnly(sal_Bool bRO);
|
|
// calculate an optimal size. Basically, this takes into account the number of visible rows.
|
|
Size CalcOptimalSize( const Size& _rAvailable );
|
|
|
|
// can the current content be cut
|
|
sal_Bool isPasteAllowed();
|
|
sal_Bool isCutAllowed();
|
|
sal_Bool isCopyAllowed();
|
|
void cut();
|
|
void paste();
|
|
void copy();
|
|
|
|
virtual void GetFocus();
|
|
virtual void DeactivateCell(sal_Bool bUpdate = sal_True);
|
|
virtual void ColumnMoved( sal_uInt16 nColId ) { ColumnMoved(nColId,sal_True); }
|
|
void ColumnMoved( sal_uInt16 nColId,sal_Bool _bCreateUndo);
|
|
|
|
void Fill();
|
|
void PreFill();
|
|
|
|
/** Disables the generation of undo actions
|
|
*/
|
|
inline void EnterUndoMode() { m_bInUndoMode = sal_True; }
|
|
/** Enables the generation of undo actions
|
|
*/
|
|
inline void LeaveUndoMode() { m_bInUndoMode = sal_False; }
|
|
|
|
/** GetCellText returns the text at the given position
|
|
@param _nRow
|
|
the number of the row
|
|
@param _nColId
|
|
the ID of the column
|
|
@return
|
|
the text out of the cell
|
|
*/
|
|
virtual String GetCellText(long _nRow, sal_uInt16 _nColId) const;
|
|
|
|
/** returns the description of the row.
|
|
@param _nRow
|
|
The row number.
|
|
@return
|
|
The header text of the specified row.
|
|
*/
|
|
virtual ::rtl::OUString GetRowDescription( sal_Int32 _nRow ) const;
|
|
|
|
/** return the name of the specified object.
|
|
@param eObjType
|
|
The type to ask for
|
|
@param _nPosition
|
|
The position of a tablecell (index position), header bar colum/row cell
|
|
@return
|
|
The name of the specified object.
|
|
*/
|
|
virtual ::rtl::OUString GetAccessibleObjectName( ::svt::AccessibleBrowseBoxObjType eObjType,sal_Int32 _nPosition = -1) const;
|
|
|
|
// IAccessibleTableProvider
|
|
/** Creates the accessible object of a data table cell.
|
|
@param nRow The row index of the cell.
|
|
@param nColumnId The column ID of the cell.
|
|
@return The XAccessible interface of the specified cell. */
|
|
virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > CreateAccessibleCell( sal_Int32 nRow, sal_uInt16 nColumnId );
|
|
|
|
|
|
protected:
|
|
virtual sal_Bool SeekRow( long nRow );
|
|
|
|
virtual void PaintStatusCell(OutputDevice& rDev, const Rectangle& rRect) const;
|
|
virtual void PaintCell(OutputDevice& rDev, const Rectangle& rRect,
|
|
sal_uInt16 nColumnId ) const;
|
|
|
|
virtual sal_Int8 AcceptDrop( const BrowserAcceptDropEvent& rEvt );
|
|
virtual sal_Int8 ExecuteDrop( const BrowserExecuteDropEvent& rEvt );
|
|
virtual void MouseButtonDown( const BrowserMouseEvent& rEvt );
|
|
virtual void MouseButtonUp( const BrowserMouseEvent& rEvt );
|
|
virtual void KeyInput( const KeyEvent& rEvt );
|
|
virtual void Command(const CommandEvent& rEvt);
|
|
virtual void ArrangeControls(sal_uInt16& nX, sal_uInt16 nY);
|
|
|
|
virtual ::svt::CellController* GetController(long nRow, sal_uInt16 nCol);
|
|
virtual void InitController(::svt::CellControllerRef& rController, long nRow, sal_uInt16 nCol);
|
|
virtual void CellModified();
|
|
virtual sal_Bool SaveModified();
|
|
virtual void Init();
|
|
virtual sal_uInt32 GetTotalCellWidth(long nRow, sal_uInt16 nColId) const;
|
|
virtual void ColumnResized( sal_uInt16 nColId );
|
|
|
|
virtual sal_uInt32 GetTotalCellWidth(long nRow, sal_uInt16 nColId);
|
|
|
|
virtual sal_uInt16 GetDefaultColumnWidth(const String& rName) const;
|
|
// if you want to have an own header ...
|
|
virtual BrowserHeader* imp_CreateHeaderBar(BrowseBox* pParent);
|
|
|
|
void stopTimer();
|
|
void startTimer();
|
|
|
|
private:
|
|
OTableFieldDescRef FindFirstFreeCol(sal_uInt16& _rColumnPosition);
|
|
// rCol enthaelt die Nummer (in pOTableFieldDescList) der ersten Spalte, die von sich sagt, dass sie leer ist
|
|
// wenn es keine solche gibt, ist rCol undefiniert und der Rueckgabewert NULL
|
|
void CheckFreeColumns(sal_uInt16& _rColumnPosition);
|
|
// testet, ob es noch freie Spalten gibt, wenn nicht, wird ein neuer Packen angefuegt
|
|
// rCol enthaelt die Nummer der ersten freien Spalte (in pOTableFieldDescList)
|
|
|
|
void RemoveField( sal_uInt16 nId );
|
|
Rectangle GetInvalidRect( sal_uInt16 nColId );
|
|
long GetRealRow(long nRow) const;
|
|
long GetBrowseRow(long nRowId) const;
|
|
sal_Bool GetFunctionName(sal_uInt32 _nFunctionTokenId,String& rFkt);
|
|
void appendUndoAction(const String& _rOldValue,const String& _rNewValue,sal_Int32 _nRow,sal_Bool& _bListAction);
|
|
void appendUndoAction(const String& _rOldValue,const String& _rNewValue,sal_Int32 _nRow);
|
|
OTableFields& getFields() const;
|
|
void enableControl(const OTableFieldDescRef& _rEntry,Window* _pControl);
|
|
void setTextCellContext(const OTableFieldDescRef& _rEntry,const String& _sText,const rtl::OString& _sHelpId);
|
|
void invalidateUndoRedo();
|
|
OTableFieldDescRef getEntry(OTableFields::size_type _nPos);
|
|
|
|
void adjustSelectionMode( sal_Bool _bClickedOntoHeader, sal_Bool _bClickedOntoHandleCol );
|
|
|
|
/** save the filed change in save modified
|
|
@param _sFieldName
|
|
The field name inserted by the user.
|
|
@param _pEntry
|
|
The entry which will contain the nescessary entries.
|
|
@param _bListAction
|
|
Will be set to <TRUE/> when we are in a list action otherwise <FALSE/>
|
|
@return
|
|
<TRUE/> if an error occurred otherwise <FALSE/>
|
|
*/
|
|
sal_Bool saveField(const String& _sFieldName,OTableFieldDescRef& _pEntry,sal_Bool& _bListAction);
|
|
|
|
/** sets the table window at the _pEntry
|
|
@param _pEntry
|
|
The entry where the window should be set.
|
|
@param _sTableName
|
|
The table name to search for.
|
|
@return
|
|
<TRUE/> if the table name was set otherwise <FALSE/>
|
|
*/
|
|
sal_Bool fillEntryTable(OTableFieldDescRef& _pEntry,const ::rtl::OUString& _sTableName);
|
|
|
|
/** uses the parse node to fill all information into the field
|
|
@param _pColumnRef
|
|
The parse node used to fill the info into the field.
|
|
@param _xMetaData
|
|
Use to parse the node to a string.
|
|
@param _pEntry
|
|
The entry which will contain the nescessary entries.
|
|
@param _bListAction
|
|
Will be set to <TRUE/> when we are in a list action otherwise <FALSE/>
|
|
@return
|
|
<TRUE/> if an error occurred otherwise <FALSE/>
|
|
*/
|
|
sal_Bool fillColumnRef( const ::connectivity::OSQLParseNode* _pColumnRef,
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _rxConnection,
|
|
OTableFieldDescRef& _pEntry,
|
|
sal_Bool& _bListAction);
|
|
sal_Bool fillColumnRef( const ::rtl::OUString& _sColumnName,
|
|
const ::rtl::OUString& _sTableRange,
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDatabaseMetaData >& _xMetaData,
|
|
OTableFieldDescRef& _pEntry,
|
|
sal_Bool& _bListAction);
|
|
|
|
|
|
/** append an undo action for the table field
|
|
@param _sOldAlias
|
|
The old table alias.
|
|
@param _sAlias
|
|
The new alias name.
|
|
@param _bListAction
|
|
Will be set to <TRUE/> when we are in a list action otherwise <FALSE/>
|
|
*/
|
|
void notifyTableFieldChanged(const String& _sOldAlias,const String& _sAlias,sal_Bool& _bListAction,sal_uInt16 _nColumnId);
|
|
|
|
/** append an undo action for the function field
|
|
@param _sOldFunctionName
|
|
The old value.
|
|
@param _sFunctionName
|
|
The new function name.
|
|
@param _bListAction
|
|
Will be set to <TRUE/> when we are in a list action otherwise <FALSE/>
|
|
*/
|
|
void notifyFunctionFieldChanged(const String& _sOldFunctionName,const String& _sFunctionName,sal_Bool& _bListAction,sal_uInt16 _nColumnId);
|
|
|
|
/** clears the function fields of the submitted entry if it doesn't match the SQL standard and append an undo action.
|
|
E.q. AGGREGATE functions are only valid when the field name isn't an asterix
|
|
@param _sFieldName
|
|
The field name.
|
|
@param _pEntry
|
|
The entry to be cleared
|
|
@param _bListAction
|
|
When <TRUE/> an list action will be created.
|
|
*/
|
|
void clearEntryFunctionField(const String& _sFieldName,OTableFieldDescRef& _pEntry,sal_Bool& _bListAction,sal_uInt16 _nColumnId);
|
|
|
|
/** remove or insert the necessary function types
|
|
@param _pEntry
|
|
The currently edited entry.
|
|
*/
|
|
void setFunctionCell(OTableFieldDescRef& _pEntry);
|
|
|
|
private:
|
|
using ::svt::EditBrowseBox::AcceptDrop;
|
|
using ::svt::EditBrowseBox::ExecuteDrop;
|
|
using ::svt::EditBrowseBox::MouseButtonDown;
|
|
using ::svt::EditBrowseBox::MouseButtonUp;
|
|
};
|
|
}
|
|
#endif // DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|