/************************************************************************* * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef DBAUI_QUERYDESIGNVIEW_HXX #define DBAUI_QUERYDESIGNVIEW_HXX #include "queryview.hxx" #include #include #include "QEnumTypes.hxx" #include #include "querycontroller.hxx" #include "ConnectionLineData.hxx" namespace connectivity { class OSQLParseNode; } class ComboBox; namespace dbaui { enum SqlParseError { eIllegalJoin, eStatementTooLong, eNoConnection, eNoSelectStatement, eStatementTooComplex, eColumnInLikeNotFound, eNoColumnInLike, eColumnNotFound, eNativeMode, eTooManyTables, eTooManyConditions, eTooManyColumns, eIllegalJoinCondition, eOk }; class OQueryViewSwitch; class OAddTableDlg; class OQueryTableWindow; class OSelectionBrowseBox; class OTableConnection; class OQueryTableConnectionData; class OQueryContainerWindow; class OQueryDesignView : public OQueryView { enum ChildFocusState { SELECTION, TABLEVIEW, NONE }; Splitter m_aSplitter; ::com::sun::star::lang::Locale m_aLocale; ::rtl::OUString m_sDecimalSep; OSelectionBrowseBox* m_pSelectionBox; // presents the lower window ChildFocusState m_eChildFocus; sal_Bool m_bInKeyEvent; sal_Bool m_bInSplitHandler; public: OQueryDesignView(OQueryContainerWindow* pParent, OQueryController& _rController,const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& ); virtual ~OQueryDesignView(); virtual sal_Bool isCutAllowed(); virtual sal_Bool isPasteAllowed(); virtual sal_Bool isCopyAllowed(); 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); // check if the statement is correct when not returning false virtual sal_Bool checkStatement(); // 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(); virtual void initialize(); // window overloads virtual long PreNotify( NotifyEvent& rNEvt ); virtual void GetFocus(); sal_Bool isSlotEnabled(sal_Int32 _nSlotId); void setSlotEnabled(sal_Int32 _nSlotId,sal_Bool _bEnable); void setNoneVisbleRow(sal_Int32 _nRows); ::com::sun::star::lang::Locale getLocale() const { return m_aLocale;} ::rtl::OUString getDecimalSeparator() const { return m_sDecimalSep;} SqlParseError InsertField( const OTableFieldDescRef& rInfo, sal_Bool bVis=sal_True, sal_Bool bActivate = sal_True); bool HasFieldByAliasName(const ::rtl::OUString& rFieldName, OTableFieldDescRef& rInfo) const; // save the position of the table window and the pos of the splitters // 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); sal_Int32 getColWidth( sal_uInt16 _nColPos) const; void fillValidFields(const ::rtl::OUString& strTableName, ComboBox* pFieldList); void SaveUIConfig(); void stopTimer(); void startTimer(); void reset(); /** initializes the view from the current parser / parse iterator of the controller @param _pErrorInfo When not , the instance pointed to by this parameter takes the error which happened during the initialization. If it is not , then any such error will be displayed, using the controller's showError method. @return if and only if the initialization was successful */ bool initByParseIterator( ::dbtools::SQLExceptionInfo* _pErrorInfo ); void initByFieldDescriptions( const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue >& i_rFieldDescriptions ); ::connectivity::OSQLParseNode* getPredicateTreeFromEntry( OTableFieldDescRef pEntry, const String& _sCriteria, ::rtl::OUString& _rsErrorMessage, ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet>& _rxColumn) const; void fillFunctionInfo( const ::connectivity::OSQLParseNode* pNode ,const ::rtl::OUString& sFunctionTerm ,OTableFieldDescRef& aInfo); protected: // return the Rectangle where I can paint myself virtual void resizeDocumentView(Rectangle& rRect); DECL_LINK( SplitHdl, void* ); private: using OQueryView::SaveTabWinUIConfig; }; } #endif // DBAUI_QUERYDESIGNVIEW_HXX