2001-02-05 08:35:57 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: SelectionBrowseBox.hxx,v $
|
|
|
|
*
|
2001-10-26 06:49:36 +00:00
|
|
|
* $Revision: 1.11 $
|
2001-02-05 08:35:57 +00:00
|
|
|
*
|
2001-10-26 06:49:36 +00:00
|
|
|
* last change: $Author: oj $ $Date: 2001-10-26 07:49:36 $
|
2001-02-05 08:35:57 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (the License); You may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of the
|
|
|
|
* License at http://www.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an AS IS basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
#ifndef DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
|
|
#define DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
|
|
|
2001-06-29 07:45:10 +00:00
|
|
|
#ifndef _SVTOOLS_EDITBROWSEBOX_HXX_
|
|
|
|
#include <svtools/editbrowsebox.hxx>
|
|
|
|
#endif
|
2001-10-05 05:49:21 +00:00
|
|
|
//#ifndef DBAUI_QUERYCONTROLLER_HXX
|
|
|
|
//#include "querycontroller.hxx"
|
|
|
|
//#endif
|
2001-02-05 08:35:57 +00:00
|
|
|
#ifndef DBAUI_TABLEFIELDDESC_HXX
|
|
|
|
#include "TableFieldDescription.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBAUI_JOINEXCHANGE_HXX
|
|
|
|
#include "JoinExchange.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBAUI_ENUMTYPES_HXX
|
|
|
|
#include "QEnumTypes.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UTIL_XNUMBERFORMATTER_HPP_
|
|
|
|
#include <com/sun/star/util/XNumberFormatter.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _STRING_HXX
|
|
|
|
#include <tools/string.hxx>
|
|
|
|
#endif
|
2001-03-30 12:06:46 +00:00
|
|
|
#ifndef _TRANSFER_HXX
|
|
|
|
#include <svtools/transfer.hxx>
|
|
|
|
#endif
|
2001-02-05 08:35:57 +00:00
|
|
|
|
|
|
|
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;
|
2001-06-29 07:45:10 +00:00
|
|
|
class OSelectionBrowseBox : public ::svt::EditBrowseBox
|
2001-02-05 08:35:57 +00:00
|
|
|
{
|
|
|
|
friend class OQueryDesignView;
|
|
|
|
::std::vector<FASTBOOL> m_bVisibleRow; // an Pos steht die RowId
|
2001-04-18 12:20:48 +00:00
|
|
|
Timer m_timerInvalidate;
|
2001-02-05 08:35:57 +00:00
|
|
|
|
|
|
|
long m_nSeekRow;
|
|
|
|
BrowserMode m_nMode; // Merken des BrowseModes
|
|
|
|
Edit* m_pTextCell;
|
2001-06-29 07:45:10 +00:00
|
|
|
::svt::CheckBoxControl* m_pVisibleCell;
|
|
|
|
::svt::ComboBoxControl* m_pFieldCell;
|
|
|
|
::svt::ListBoxControl* m_pFunctionCell;
|
|
|
|
::svt::ListBoxControl* m_pTableCell;
|
|
|
|
::svt::ListBoxControl* m_pOrderCell;
|
2001-02-05 08:35:57 +00:00
|
|
|
|
2001-10-05 05:49:21 +00:00
|
|
|
OTableFieldDescRef m_pEmptyEntry; // default entry in the list may reference more than once
|
|
|
|
|
2001-02-05 08:35:57 +00:00
|
|
|
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;
|
2001-04-18 12:20:48 +00:00
|
|
|
sal_Bool m_bStopTimer;
|
2001-10-23 11:30:27 +00:00
|
|
|
sal_Bool m_bWasEditing;
|
2001-02-05 08:35:57 +00:00
|
|
|
|
2001-04-18 12:20:48 +00:00
|
|
|
DECL_LINK(OnInvalidateTimer, void*);
|
2001-02-05 08:35:57 +00:00
|
|
|
public: OSelectionBrowseBox( Window* pParent );
|
|
|
|
~OSelectionBrowseBox();
|
|
|
|
|
|
|
|
void initialize();
|
2001-10-05 05:49:21 +00:00
|
|
|
OTableFieldDescRef InsertField( const OJoinExchangeData& jxdSource, long nColId=-1, sal_Bool bVis=sal_True, sal_Bool bActivate=sal_True );
|
|
|
|
OTableFieldDescRef InsertField( const OTableFieldDescRef& rInfo, long nCol=-1, sal_Bool bVis=sal_True, sal_Bool bActivate=sal_True );
|
|
|
|
void InsertColumn( OTableFieldDescRef pEntry, long& nColId );
|
2001-02-05 08:35:57 +00:00
|
|
|
void RemoveColumn( sal_uInt16 nColId );
|
|
|
|
void DeleteFields( const String& rAliasName );
|
|
|
|
// AddGroupBy:: F"ugt ein Feld mit Funktion == Grupierung. Falls das Feld schon vorhanden ist und ein Aggregate Funktion
|
|
|
|
// benutzt, wird das Flag nicht gesetzt
|
2001-10-05 05:49:21 +00:00
|
|
|
void AddGroupBy( const OTableFieldDescRef& rInfo );
|
|
|
|
void AddCondition( const OTableFieldDescRef& rInfo,
|
2001-02-05 08:35:57 +00:00
|
|
|
const String& rValue,
|
|
|
|
const sal_uInt16 nLevel, const char* pOp=0 );
|
2001-10-05 05:49:21 +00:00
|
|
|
void AddOrder(const OTableFieldDescRef& rInfo, const EOrderDir eDir, sal_uInt16& nPos);
|
2001-02-05 08:35:57 +00:00
|
|
|
void ClearAll();
|
2001-10-05 05:49:21 +00:00
|
|
|
OTableFieldDescRef AppendNewCol( sal_uInt16 nCnt=1 );
|
2001-09-27 05:19:05 +00:00
|
|
|
sal_Bool Save();
|
2001-02-05 08:35:57 +00:00
|
|
|
OQueryDesignView* getDesignView();
|
|
|
|
OQueryDesignView* getDesignView() const;
|
|
|
|
void SetColWidth();
|
|
|
|
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_uInt16 nCellIndex, long nColId);
|
|
|
|
void SetCellContents(sal_uInt16 nCellIndex, long 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);
|
|
|
|
|
2001-04-18 10:44:59 +00:00
|
|
|
// can the current content be cut
|
|
|
|
sal_Bool isCutAllowed();
|
|
|
|
void cut();
|
|
|
|
void paste();
|
|
|
|
void copy();
|
|
|
|
|
2001-10-22 08:57:52 +00:00
|
|
|
virtual void GetFocus();
|
2001-10-26 06:49:36 +00:00
|
|
|
virtual void DeactivateCell(sal_Bool bUpdate = sal_True);
|
2001-10-22 08:57:52 +00:00
|
|
|
|
2001-02-05 08:35:57 +00:00
|
|
|
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;
|
|
|
|
|
2001-03-30 12:06:46 +00:00
|
|
|
virtual sal_Int8 AcceptDrop( const BrowserAcceptDropEvent& rEvt );
|
|
|
|
virtual sal_Int8 ExecuteDrop( const BrowserExecuteDropEvent& rEvt );
|
2001-02-05 08:35:57 +00:00
|
|
|
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);
|
|
|
|
|
2001-06-29 07:45:10 +00:00
|
|
|
virtual ::svt::CellController* GetController(long nRow, sal_uInt16 nCol);
|
|
|
|
virtual void InitController(::svt::CellControllerRef& rController, long nRow, sal_uInt16 nCol);
|
2001-02-05 08:35:57 +00:00
|
|
|
virtual void CellModified();
|
|
|
|
virtual sal_Bool SaveModified();
|
|
|
|
virtual void Init();
|
|
|
|
virtual String GetCellText(long nRow, sal_uInt16 nColId) const;
|
|
|
|
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;
|
|
|
|
|
|
|
|
void Fill();
|
|
|
|
|
2001-04-18 12:20:48 +00:00
|
|
|
void stopTimer();
|
|
|
|
void startTimer();
|
|
|
|
|
2001-02-05 08:35:57 +00:00
|
|
|
private:
|
2001-10-05 05:49:21 +00:00
|
|
|
OTableFieldDescRef FindFirstFreeCol(long & rCol);
|
2001-02-05 08:35:57 +00:00
|
|
|
// 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(long& rCol);
|
|
|
|
// testet, ob es noch freie Spalten gibt, wenn nicht, wird ein neuer Packen angefuegt
|
|
|
|
// rCol enthaelt die Nummer der ersten freien Spalte (in pOTableFieldDescList)
|
|
|
|
|
2001-10-05 05:49:21 +00:00
|
|
|
void RemoveField( sal_uInt16 nId, sal_Bool bActivate = sal_True);
|
|
|
|
Rectangle GetInvalidRect( sal_uInt16 nColId );
|
|
|
|
long GetRealRow(long nRow) const;
|
|
|
|
long GetBrowseRow(long nRowId) const;
|
|
|
|
sal_Bool GetFunktionName(String& rFkt);
|
|
|
|
void appendUndoAction(const String& _rOldValue,const String& _rNewValue,sal_Int32 _nRow);
|
|
|
|
void PreFill();
|
|
|
|
OTableFields& getFields() const;
|
|
|
|
void enableControl(const OTableFieldDescRef& _rEntry,Window* _pControl);
|
|
|
|
void setTextCellContext(const OTableFieldDescRef& _rEntry,const String& _sText,ULONG _nHelpId);
|
|
|
|
void invalidateUndoRedo();
|
|
|
|
OTableFieldDescRef getEntry(OTableFields::size_type _nPos);
|
2001-02-05 08:35:57 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
#endif // DBAUI_QUERYDESIGN_OSELECTIONBROWSEBOX_HXX
|
|
|
|
|
|
|
|
|
|
|
|
|