123 lines
5.4 KiB
C++
123 lines
5.4 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* 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 .
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "viewfunc.hxx"
|
|
#include <dptypes.hxx>
|
|
|
|
namespace com::sun::star::sheet { struct DataPilotFieldFilter; }
|
|
struct ScSortParam;
|
|
struct ScQueryParam;
|
|
class ScDBData;
|
|
class ScDPObject;
|
|
class ScDPSaveData;
|
|
struct ScDPNumGroupInfo;
|
|
struct ScSubTotalParam;
|
|
|
|
class SAL_DLLPUBLIC_RTTI ScDBFunc : public ScViewFunc
|
|
{
|
|
private:
|
|
void GetSelectedMemberList(ScDPUniqueStringSet& rEntries, tools::Long& rDimension);
|
|
static void ModifiedAutoFilter(ScDocShell* pDocSh);
|
|
static void ApplyAutoFilter(ScDocShell* pDocSh, ScViewData* pViewData, ScDBData* pDBData,
|
|
SCROW nRow, SCTAB nTab, const ScQueryParam& aParam);
|
|
|
|
DECL_STATIC_LINK(ScDBFunc, InstallLOKNotifierHdl, void*, vcl::ILibreOfficeKitNotifier*);
|
|
|
|
public:
|
|
ScDBFunc( vcl::Window* pParent, ScDocShell& rDocSh, ScTabViewShell* pViewShell );
|
|
virtual ~ScDBFunc();
|
|
|
|
// only UISort repeat the partial results if necessary
|
|
|
|
void UISort( const ScSortParam& rSortParam );
|
|
|
|
void Sort( const ScSortParam& rSortParam,
|
|
bool bRecord = true, bool bPaint = true );
|
|
SC_DLLPUBLIC void Query( const ScQueryParam& rQueryParam,
|
|
const ScRange* pAdvSource, bool bRecord );
|
|
void DoSubTotals( const ScSubTotalParam& rParam, bool bRecord = true,
|
|
const ScSortParam* pForceNewSort = nullptr );
|
|
|
|
void ToggleAutoFilter();
|
|
void HideAutoFilter();
|
|
|
|
void RepeatDB( bool bRecord = true );
|
|
|
|
bool ImportData( const ScImportParam& rParam );
|
|
|
|
void GotoDBArea( const OUString& rDBName );
|
|
|
|
// DB range from Cursor
|
|
ScDBData* GetDBData( bool bMarkArea = true, ScGetDBMode eMode = SC_DB_MAKE, ScGetDBSelection eSel = ScGetDBSelection::Keep);
|
|
ScDBData* GetAnonymousDBData();
|
|
|
|
void Consolidate( const ScConsolidateParam& rParam );
|
|
|
|
bool MakePivotTable(
|
|
const ScDPSaveData& rData, const ScRange& rDest, bool bNewTable,
|
|
const ScDPObject& rSource );
|
|
|
|
void DeletePivotTable();
|
|
void RecalcPivotTable();
|
|
bool HasSelectionForDateGroup( ScDPNumGroupInfo& rOldInfo, sal_Int32& rParts );
|
|
bool HasSelectionForNumGroup( ScDPNumGroupInfo& rOldInfo );
|
|
void GroupDataPilot();
|
|
void DateGroupDataPilot( const ScDPNumGroupInfo& rInfo, sal_Int32 nParts );
|
|
void NumGroupDataPilot( const ScDPNumGroupInfo& rInfo );
|
|
void UngroupDataPilot();
|
|
void DataPilotInput( const ScAddress& rPos, const OUString& rString );
|
|
|
|
void DataPilotSort(ScDPObject* pDPObject, tools::Long nDimIndex, bool bAscending, const sal_uInt16* pUserListId = nullptr);
|
|
bool DataPilotMove( const ScRange& rSource, const ScAddress& rDest );
|
|
|
|
bool HasSelectionForDrillDown( css::sheet::DataPilotFieldOrientation& rOrientation );
|
|
void SetDataPilotDetails(bool bShow, const OUString* pNewDimensionName = nullptr);
|
|
|
|
void ShowDataPilotSourceData( ScDPObject& rDPObj,
|
|
const css::uno::Sequence< css::sheet::DataPilotFieldFilter >& rFilters );
|
|
|
|
void MakeOutline( bool bColumns, bool bRecord = true );
|
|
void RemoveOutline( bool bColumns, bool bRecord = true );
|
|
void RemoveAllOutlines( bool bRecord = true );
|
|
void TestRemoveOutline( bool& rCol, bool& rRow );
|
|
|
|
void AutoOutline();
|
|
|
|
void SelectLevel( bool bColumns, sal_uInt16 nLevel,
|
|
bool bRecord = true );
|
|
void SetOutlineState( bool bColumn, sal_uInt16 nLevel, sal_uInt16 nEntry, bool bHidden);
|
|
void ShowOutline( bool bColumns, sal_uInt16 nLevel, sal_uInt16 nEntry,
|
|
bool bRecord = true, bool bPaint = true );
|
|
void HideOutline( bool bColumns, sal_uInt16 nLevel, sal_uInt16 nEntry,
|
|
bool bRecord = true, bool bPaint = true );
|
|
|
|
void ShowMarkedOutlines( bool bRecord = true );
|
|
void HideMarkedOutlines( bool bRecord = true );
|
|
bool OutlinePossible(bool bHide);
|
|
|
|
void UpdateCharts(bool bAllCharts); // Default: at the Cursor
|
|
|
|
static sal_uInt16 DoUpdateCharts( const ScAddress& rPos, ScDocument& rDoc, bool bAllCharts );
|
|
|
|
void OnLOKShowHideColRow(bool bColumns, SCCOLROW nStartRow);
|
|
};
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|