/*************************************************************************
 *
 * 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 __com_sun_star_sheet_XDatabaseRange_idl__
#define __com_sun_star_sheet_XDatabaseRange_idl__

#ifndef __com_sun_star_uno_XInterface_idl__
#include <com/sun/star/uno/XInterface.idl>
#endif

#ifndef __com_sun_star_table_CellRangeAddress_idl__
#include <com/sun/star/table/CellRangeAddress.idl>
#endif

#ifndef __com_sun_star_beans_PropertyValue_idl__
#include <com/sun/star/beans/PropertyValue.idl>
#endif

#ifndef __com_sun_star_sheet_XSheetFilterDescriptor_idl__
#include <com/sun/star/sheet/XSheetFilterDescriptor.idl>
#endif

#ifndef __com_sun_star_sheet_XSubTotalDescriptor_idl__
#include <com/sun/star/sheet/XSubTotalDescriptor.idl>
#endif

//=============================================================================

module com {  module sun {  module star {  module sheet {

//=============================================================================

/** provides access to the settings and options of a database range.

	@see com::sun::star::sheet::DatabaseRange
 */
published interface XDatabaseRange: com::sun::star::uno::XInterface
{
	//-------------------------------------------------------------------------

	/** returns the data area of the database range in the
		spreadsheet document.
	 */
	com::sun::star::table::CellRangeAddress getDataArea();

	//-------------------------------------------------------------------------

	/** sets the data area of the database range.
	 */
	void setDataArea( [in] com::sun::star::table::CellRangeAddress aDataArea );

	//-------------------------------------------------------------------------

	/** returns the sort descriptor stored with the database range.

		@see SheetSortDescriptor2
	 */
	sequence< com::sun::star::beans::PropertyValue > getSortDescriptor();

	//-------------------------------------------------------------------------

	/** returns the filter descriptor stored with the database range.

		<p>If the filter descriptor is modified, the new filtering is
		carried out when <member>XDatabaseRange::refresh()</member> is
		called.</p>
		
		@see SheetFilterDescriptor
	 */
	XSheetFilterDescriptor getFilterDescriptor();

	//-------------------------------------------------------------------------

	/** returns the subtotal descriptor stored with the database range.

		<p>If the subtotal descriptor is modified, the new subtotals are
		inserted when <member>XDatabaseRange::refresh()</member> is
		called.</p>

		@see SubTotalDescriptor
	 */
	XSubTotalDescriptor getSubTotalDescriptor();

	//-------------------------------------------------------------------------

	/** returns the database import descriptor stored with this database
		range.

		@see DatabaseImportDescriptor
	 */
	sequence< com::sun::star::beans::PropertyValue > getImportDescriptor();

	//-------------------------------------------------------------------------

	/** executes the stored import, filter, sorting, and subtotals
		descriptors again.
	 */
	void refresh();

};

//=============================================================================

}; }; }; };

#endif