summaryrefslogtreecommitdiff
path: root/dbaccess/source/ui/inc/QueryDesignView.hxx
diff options
context:
space:
mode:
authorOcke Janssen <oj@openoffice.org>2001-02-05 08:10:26 +0000
committerOcke Janssen <oj@openoffice.org>2001-02-05 08:10:26 +0000
commit923fd8112b32d8f4e11a0629a75fb3fe67efccf3 (patch)
tree5c8694b70e0e57312c07b79fbd3f4caf990f49f8 /dbaccess/source/ui/inc/QueryDesignView.hxx
parente66b25aeb267676541974d474e5c6613ac700edf (diff)
querydesign
Diffstat (limited to 'dbaccess/source/ui/inc/QueryDesignView.hxx')
-rw-r--r--dbaccess/source/ui/inc/QueryDesignView.hxx220
1 files changed, 220 insertions, 0 deletions
diff --git a/dbaccess/source/ui/inc/QueryDesignView.hxx b/dbaccess/source/ui/inc/QueryDesignView.hxx
new file mode 100644
index 000000000000..6f798f16b20a
--- /dev/null
+++ b/dbaccess/source/ui/inc/QueryDesignView.hxx
@@ -0,0 +1,220 @@
+/*************************************************************************
+ *
+ * $RCSfile: QueryDesignView.hxx,v $
+ *
+ * $Revision: 1.1 $
+ *
+ * last change: $Author: oj $ $Date: 2001-02-05 09:10:20 $
+ *
+ * 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_QUERYDESIGNVIEW_HXX
+#define DBAUI_QUERYDESIGNVIEW_HXX
+
+#ifndef DBAUI_QUERYVIEW_HXX
+#include "queryview.hxx"
+#endif
+#ifndef _SV_SPLIT_HXX
+#include <vcl/split.hxx>
+#endif
+#ifndef _VECTOR_
+#include <vector>
+#endif
+#ifndef _STRING_HXX
+#include <tools/string.hxx>
+#endif
+#ifndef DBAUI_QUERYTABLEVIEW_HXX
+#include "QueryTableView.hxx"
+#endif
+#ifndef DBAUI_ENUMTYPES_HXX
+#include "QEnumTypes.hxx"
+#endif
+
+namespace connectivity
+{
+ class OSQLParseNode;
+}
+
+class ComboBox;
+namespace dbaui
+{
+ class OQueryViewSwitch;
+ class OAddTableDlg;
+ class OQueryTableWindow;
+ class OTableFieldDesc;
+ class OSelectionBrowseBox;
+ class OTableConnection;
+ class OQueryTableConnectionData;
+ class OConnectionLineData;
+
+ class OQueryDesignView : public OQueryView
+ {
+ friend class OQueryViewSwitch;
+
+ Splitter m_aSplitter;
+
+ ::com::sun::star::lang::Locale m_aLocale;
+ ::rtl::OUString m_sDecimalSep;
+
+ OScrollWindowHelper* m_pScrollWindow; // contains only the scrollbars
+ OQueryTableView* m_pTableView; // presents the upper window
+ OAddTableDlg* m_pAddTabDlg; // create by the first execute of the add table slot
+ OSelectionBrowseBox* m_pSelectionBox; // presents the lower window
+
+ ::rtl::OUString QuoteField( const ::rtl::OUString& rValue, sal_Int32 aType );
+ void InitFromParseNode();
+ void GetTable( ::rtl::OUString& rDatabase, ::rtl::OUString& rTable, ::rtl::OUString& rAlias, ::connectivity::OSQLParseNode* pNode );
+
+ void GenerateInnerJoinCriterias(::rtl::OUString& _rJoinCrit,const ::std::vector<OTableConnection*>* _pConnList);
+ // erzeugt das Group Argument, falls vorhanden
+ ::rtl::OUString GenerateGroupBy(::std::vector<OTableFieldDesc*>* pFieldList, sal_Bool bMulti );
+ // erzeugt Where und Having Argument, falls vorhanden
+ sal_Bool GenerateCriterias(::rtl::OUString& aRetStr,::rtl::OUString& rHavingStr/*,::rtl::OUString& rOrderStr*/, ::std::vector<OTableFieldDesc*>* pFieldList, sal_Bool bMulti );
+ ::rtl::OUString GenerateOrder( ::std::vector<OTableFieldDesc*>* pFieldList , sal_Bool bMulti);
+ // Erzeugt die SelectList. bAlias mu"s gesetzt sein, wenn mehr als 1 Tabelle vorhanden ist
+ ::rtl::OUString GenerateSelectList(::std::vector<OTableFieldDesc*>* pFieldList,sal_Bool bAlias);
+ // Erzeugt die Tabellenliste mit Joins aus pConnList, wenn bJoin == True. pConnList kann == NULL wenn bJoin == sal_False
+ ::rtl::OUString GenerateFromClause(const OJoinTableView::OTableWindowMap* pTabMap,::std::vector<OTableConnection*>* pConnList);
+
+ ::rtl::OUString BuildACriteria( const ::rtl::OUString& rVal, sal_Int32 aType );
+ int InstallFields( const ::connectivity::OSQLParseNode* pNode, OJoinTableView::OTableWindowMap* pTabList );
+
+ // nLevel gibt die Zeile an in der die Bedingungen eingetragen werden sollen
+ int GetSelectionCriteria(const ::connectivity::OSQLParseNode* pNode ,int &nLevel, sal_Bool bJoinWhere=sal_False);
+ void GetHavingCriteria(const ::connectivity::OSQLParseNode* pNode ,int &nLevel);
+
+ int GetORCriteria(const ::connectivity::OSQLParseNode * pCondition, int& nLevel, sal_Bool bHaving = sal_False );
+ int GetANDCriteria(const ::connectivity::OSQLParseNode * pCondition, const int nLevel, sal_Bool bHaving);
+ int ComparsionPredicate( const ::connectivity::OSQLParseNode * pCondition, const int nLevel, sal_Bool bHaving );
+
+ void GetOrderCriteria( const ::connectivity::OSQLParseNode* pNode );
+ void GetGroupCriteria( const ::connectivity::OSQLParseNode* pNode );
+
+ sal_Bool GetInnerJoinCriteria(const ::connectivity::OSQLParseNode *pCondition);
+ void FillOuterJoins(const ::connectivity::OSQLParseNode* pParseNode);
+ sal_Bool InsertJoin(const ::connectivity::OSQLParseNode *pNode);
+ sal_Bool InsertJoinConnection(const ::connectivity::OSQLParseNode *pNode, const EJoinType& _eJoinType);
+
+ sal_Bool FillDragInfo(const ::connectivity::OSQLParseNode* pTableRef,OTableFieldDesc& aDragInfo);
+
+ sal_Bool HasFields();
+ ::rtl::OUString BuildTable(const OQueryTableWindow* pEntryTab);
+
+ ::rtl::OUString BuildJoin(OQueryTableWindow* pLh, OQueryTableWindow* pRh, OQueryTableConnectionData* pData);
+ ::rtl::OUString BuildJoin(const ::rtl::OUString &rLh, OQueryTableWindow* pRh, OQueryTableConnectionData* pData);
+ ::rtl::OUString BuildJoin(OQueryTableWindow* pLh, const ::rtl::OUString &rRh, OQueryTableConnectionData* pData);
+ ::rtl::OUString BuildJoin(const ::rtl::OUString& rLh, const ::rtl::OUString& rRh, OQueryTableConnectionData* pData);
+
+ ::rtl::OUString BuildJoinCriteria(::std::vector<OConnectionLineData*>* pLineDataList,OQueryTableConnectionData* pData);
+
+ void GetNextJoin(OQueryTableConnection* pEntryConn,::rtl::OUString &aJoin,OQueryTableWindow* pEntryTabTo);
+ void JoinCycle(OQueryTableConnection* pEntryConn,::rtl::OUString &rJoin,OQueryTableWindow* pEntryTabTo);
+
+ int InsertColumnRef(const ::connectivity::OSQLParseNode * pColumnRef,
+ ::rtl::OUString& aColumnName,const ::rtl::OUString& aColumnAlias,
+ ::rtl::OUString& aTableRange,OTableFieldDesc& aInfo,
+ OJoinTableView::OTableWindowMap* pTabList);
+
+ sal_Int32 GetColumnFormatKey(const ::connectivity::OSQLParseNode* pColumnRef);
+ public:
+ OQueryDesignView(Window* pParent, OQueryController* _pController,const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& );
+ virtual ~OQueryDesignView();
+
+ virtual sal_Bool isCutAllowed();
+ virtual void copy();
+ virtual void cut();
+ virtual void paste();
+ // clears the whole query
+ virtual void clear();
+ // set the view readonly or not
+ virtual void setReadOnly(sal_Bool _bReadOnly);
+ // set the statement for representation
+ virtual void setStatement(const ::rtl::OUString& _rsStatement);
+ // returns the current sql statement
+ virtual ::rtl::OUString getStatement();
+ /// late construction
+ virtual void Construct(const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControlModel >& xModel);
+ virtual void initialize();
+ // window overloads
+ virtual long PreNotify( NotifyEvent& rNEvt );
+
+ // returs the add table dialog from the design view
+ OAddTableDlg* getAddTableDialog() { return m_pAddTabDlg; }
+ BOOL IsAddAllowed();
+ sal_Bool isSlotEnabled(sal_Int32 _nSlotId);
+ void setSlotEnabled(sal_Int32 _nSlotId,sal_Bool _bEnable);
+
+ ::com::sun::star::lang::Locale getLocale() const { return m_aLocale;}
+ ::rtl::OUString getDecimalSeparator() const { return m_sDecimalSep;}
+
+ sal_Bool HasTable() const {return m_pTableView->GetTabWinMap()->size() != 0;}
+ sal_Bool InsertField( const OTableFieldDesc& rInfo, sal_Bool bVis=sal_True, sal_Bool bActivate = sal_True);
+ // save the position of the table window and the pos of the splitters
+ void SaveTabWinUIConfig(OQueryTableWindow* pWin);
+ // called when fields are deleted
+ void DeleteFields( const ::rtl::OUString& rAliasName );
+ // called when a table from tabeview was deleted
+ void TableDeleted(const ::rtl::OUString& rAliasName);
+
+ OQueryTableView* getTableView() { return m_pTableView; }
+ BOOL getColWidth( const ::rtl::OUString& rAliasName, const ::rtl::OUString& rFieldName, ULONG& nWidth );
+ void fillValidFields(const ::rtl::OUString& strTableName, ComboBox* pFieldList);
+ void zoomTableView(const Fraction& _rFraction);
+ protected:
+ // return the Rectangle where I can paint myself
+ virtual void resizeControl(Rectangle& rRect);
+ DECL_LINK( SplitHdl, void* );
+ };
+}
+#endif // DBAUI_QUERYDESIGNVIEW_HXX
+