2010-10-27 12:33:13 +01:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2012-06-14 17:39:53 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the LibreOffice project.
|
|
|
|
*
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*
|
|
|
|
* This file incorporates work covered by the following license notice:
|
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
|
|
* with this work for additional information regarding copyright
|
|
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
|
|
* License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 .
|
|
|
|
*/
|
2001-10-05 05:49:45 +00:00
|
|
|
#ifndef DBAUI_TABLEFIELDDESC_HXX
|
|
|
|
#define DBAUI_TABLEFIELDDESC_HXX
|
|
|
|
|
|
|
|
#include <vector>
|
2012-06-28 13:12:59 +02:00
|
|
|
|
2001-10-05 05:49:45 +00:00
|
|
|
#include "QEnumTypes.hxx"
|
2006-06-20 02:13:59 +00:00
|
|
|
#include <rtl/ustring.hxx>
|
2004-08-02 14:54:03 +00:00
|
|
|
#include <com/sun/star/beans/PropertyValue.hpp>
|
2010-10-15 12:22:54 -05:00
|
|
|
#include <rtl/ref.hxx>
|
|
|
|
|
|
|
|
#include <salhelper/simplereferenceobject.hxx>
|
2001-10-05 05:49:45 +00:00
|
|
|
|
2010-02-15 14:34:48 +01:00
|
|
|
namespace comphelper
|
|
|
|
{
|
|
|
|
class NamedValueCollection;
|
|
|
|
}
|
|
|
|
|
2001-10-05 05:49:45 +00:00
|
|
|
class Window;
|
2012-08-12 18:38:58 +02:00
|
|
|
|
2001-10-05 05:49:45 +00:00
|
|
|
namespace dbaui
|
|
|
|
{
|
2010-10-15 12:22:54 -05:00
|
|
|
class OTableFieldDesc : public ::salhelper::SimpleReferenceObject
|
2001-10-05 05:49:45 +00:00
|
|
|
{
|
|
|
|
private:
|
2013-04-07 12:06:47 +02:00
|
|
|
::std::vector< OUString >
|
2010-02-16 15:21:07 +01:00
|
|
|
m_aCriteria;
|
2001-10-05 05:49:45 +00:00
|
|
|
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString m_aTableName;
|
|
|
|
OUString m_aAliasName; ///< table range
|
|
|
|
OUString m_aFieldName; ///< column
|
|
|
|
OUString m_aFieldAlias; ///< column alias
|
|
|
|
OUString m_aFunctionName;///< contains the function name (only if m_eFunctionType != FKT_NONE)
|
2001-10-05 05:49:45 +00:00
|
|
|
|
|
|
|
Window* m_pTabWindow;
|
|
|
|
|
|
|
|
sal_Int32 m_eDataType;
|
2002-08-30 10:08:26 +00:00
|
|
|
sal_Int32 m_eFunctionType;
|
2001-10-05 05:49:45 +00:00
|
|
|
ETableFieldType m_eFieldType;
|
|
|
|
EOrderDir m_eOrderDir;
|
|
|
|
sal_Int32 m_nIndex;
|
|
|
|
sal_Int32 m_nColWidth;
|
2002-08-19 06:32:53 +00:00
|
|
|
sal_uInt16 m_nColumnId;
|
2001-10-05 05:49:45 +00:00
|
|
|
sal_Bool m_bGroupBy;
|
|
|
|
sal_Bool m_bVisible;
|
|
|
|
|
2012-08-10 21:24:32 +02:00
|
|
|
// when adding new fields, please take care of IsEmpty!
|
2001-10-05 05:49:45 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
OTableFieldDesc();
|
2013-04-07 12:06:47 +02:00
|
|
|
OTableFieldDesc(const OUString& rTable, const OUString& rField );
|
2001-10-05 05:49:45 +00:00
|
|
|
OTableFieldDesc(const OTableFieldDesc& rRS);
|
|
|
|
~OTableFieldDesc();
|
|
|
|
|
2012-08-12 18:48:35 +02:00
|
|
|
inline sal_Bool IsEmpty() const;
|
|
|
|
|
|
|
|
OTableFieldDesc& operator=( const OTableFieldDesc& _aField );
|
|
|
|
sal_Bool operator==( const OTableFieldDesc& rDesc );
|
|
|
|
|
|
|
|
sal_Bool IsVisible() const { return m_bVisible;}
|
|
|
|
sal_Bool IsGroupBy() const { return m_bGroupBy;}
|
|
|
|
|
|
|
|
void SetVisible( sal_Bool bVis=sal_True ) { m_bVisible = bVis; }
|
|
|
|
void SetGroupBy( sal_Bool bGb=sal_False ) { m_bGroupBy = bGb; }
|
|
|
|
void SetTabWindow( Window* pWin ){ m_pTabWindow = pWin; }
|
2013-04-07 12:06:47 +02:00
|
|
|
void SetField( const OUString& rF ) { m_aFieldName = rF; }
|
|
|
|
void SetFieldAlias( const OUString& rF ) { m_aFieldAlias = rF; }
|
|
|
|
void SetTable( const OUString& rT ) { m_aTableName = rT; }
|
|
|
|
void SetAlias( const OUString& rT ) { m_aAliasName = rT; }
|
|
|
|
void SetFunction( const OUString& rT ) { m_aFunctionName = rT; }
|
2012-08-12 18:48:35 +02:00
|
|
|
void SetOrderDir( EOrderDir eDir ) { m_eOrderDir = eDir; }
|
|
|
|
void SetDataType( sal_Int32 eTyp ) { m_eDataType = eTyp; }
|
|
|
|
void SetFieldType( ETableFieldType eTyp ) { m_eFieldType = eTyp; }
|
2013-04-07 12:06:47 +02:00
|
|
|
void SetCriteria( sal_uInt16 nIdx, const OUString& rCrit );
|
2012-08-12 18:48:35 +02:00
|
|
|
void SetColWidth( sal_Int32 nWidth ) { m_nColWidth = nWidth; }
|
|
|
|
void SetFieldIndex( sal_Int32 nFieldIndex ) { m_nIndex = nFieldIndex; }
|
|
|
|
void SetFunctionType( sal_Int32 eTyp ) { m_eFunctionType = eTyp; }
|
|
|
|
void SetColumnId(sal_uInt16 _nColumnId) { m_nColumnId = _nColumnId; }
|
|
|
|
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString GetField() const { return m_aFieldName;}
|
|
|
|
OUString GetFieldAlias() const { return m_aFieldAlias;}
|
|
|
|
OUString GetTable() const { return m_aTableName;}
|
|
|
|
OUString GetAlias() const { return m_aAliasName;}
|
|
|
|
OUString GetFunction() const { return m_aFunctionName;}
|
2012-08-12 18:48:35 +02:00
|
|
|
sal_Int32 GetDataType() const { return m_eDataType; }
|
|
|
|
ETableFieldType GetFieldType() const { return m_eFieldType; }
|
|
|
|
EOrderDir GetOrderDir() const { return m_eOrderDir; }
|
2013-04-07 12:06:47 +02:00
|
|
|
OUString GetCriteria( sal_uInt16 nIdx ) const;
|
2012-08-12 18:48:35 +02:00
|
|
|
sal_Int32 GetColWidth() const { return m_nColWidth; }
|
|
|
|
sal_Int32 GetFieldIndex() const { return m_nIndex; }
|
|
|
|
Window* GetTabWindow() const { return m_pTabWindow;}
|
|
|
|
sal_Int32 GetFunctionType() const { return m_eFunctionType; }
|
|
|
|
sal_uInt16 GetColumnId() const { return m_nColumnId;}
|
|
|
|
|
|
|
|
inline sal_Bool isAggreateFunction() const { return (m_eFunctionType & FKT_AGGREGATE) == FKT_AGGREGATE; }
|
|
|
|
inline sal_Bool isOtherFunction() const { return (m_eFunctionType & FKT_OTHER) == FKT_OTHER; }
|
|
|
|
inline sal_Bool isNumeric() const { return (m_eFunctionType & FKT_NUMERIC) == FKT_NUMERIC; }
|
|
|
|
inline sal_Bool isNoneFunction() const { return m_eFunctionType == FKT_NONE; }
|
|
|
|
inline sal_Bool isCondition() const { return (m_eFunctionType & FKT_CONDITION) == FKT_CONDITION; }
|
|
|
|
inline sal_Bool isNumericOrAggreateFunction() const { return isNumeric() || isAggreateFunction(); }
|
|
|
|
|
|
|
|
sal_Bool HasCriteria() const
|
2001-10-05 05:49:45 +00:00
|
|
|
{
|
2013-04-07 12:06:47 +02:00
|
|
|
::std::vector< OUString>::const_iterator aIter = m_aCriteria.begin();
|
|
|
|
::std::vector< OUString>::const_iterator aEnd = m_aCriteria.end();
|
2009-07-03 12:24:35 +00:00
|
|
|
for(;aIter != aEnd;++aIter)
|
2011-12-19 18:10:37 -02:00
|
|
|
if(!aIter->isEmpty())
|
2001-10-05 05:49:45 +00:00
|
|
|
break;
|
2009-07-03 12:24:35 +00:00
|
|
|
return aIter != aEnd;
|
2001-10-05 05:49:45 +00:00
|
|
|
}
|
|
|
|
|
2013-04-07 12:06:47 +02:00
|
|
|
const ::std::vector< OUString>& GetCriteria() const { return m_aCriteria; }
|
2001-10-05 05:49:45 +00:00
|
|
|
|
2010-02-16 15:21:07 +01:00
|
|
|
void Load( const ::com::sun::star::beans::PropertyValue& i_rSettings, const bool i_bIncludingCriteria );
|
|
|
|
void Save( ::comphelper::NamedValueCollection& o_rSettings, const bool i_bIncludingCriteria );
|
2001-10-05 05:49:45 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
inline sal_Bool OTableFieldDesc::IsEmpty() const
|
|
|
|
{
|
2012-08-12 18:45:53 +02:00
|
|
|
sal_Bool bEmpty = (m_aTableName.isEmpty() &&
|
|
|
|
m_aAliasName.isEmpty() &&
|
|
|
|
m_aFieldName.isEmpty() &&
|
|
|
|
m_aFieldAlias.isEmpty() &&
|
|
|
|
m_aFunctionName.isEmpty() &&
|
2011-12-19 18:10:37 -02:00
|
|
|
!HasCriteria());
|
2001-10-05 05:49:45 +00:00
|
|
|
return bEmpty;
|
|
|
|
}
|
2012-08-12 18:38:58 +02:00
|
|
|
|
2012-08-12 18:48:35 +02:00
|
|
|
typedef ::rtl::Reference< OTableFieldDesc> OTableFieldDescRef;
|
|
|
|
typedef ::std::vector<OTableFieldDescRef> OTableFields;
|
2001-10-05 05:49:45 +00:00
|
|
|
}
|
2012-08-12 18:38:58 +02:00
|
|
|
#endif
|
2001-10-05 05:49:45 +00:00
|
|
|
|
2010-10-27 12:33:13 +01:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|