1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
/* This file is part of the KDE project
Copyright 2008 Stefan Nikolaus <stefan.nikolaus@kdemail.net>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef KSPREAD_ODF_SAVING_CONTEXT
#define KSPREAD_ODF_SAVING_CONTEXT
#include "Cell.h"
#include "GenValidationStyle.h"
#include "Sheet.h"
#include "calligra_sheets_limits.h"
#include <KoShapeSavingContext.h>
#include <QMap>
#include <QMultiHash>
class KoShape;
namespace Calligra
{
namespace Sheets
{
/**
* \ingroup OpenDocument
* Data used while saving.
*/
class OdfSavingContext
{
public:
OdfSavingContext(KoShapeSavingContext& shapeContext)
: shapeContext(shapeContext) {}
void insertCellAnchoredShape(const Sheet *sheet, int row, int column, KoShape* shape) {
Q_ASSERT_X(1 <= column && column <= KS_colMax, __FUNCTION__, QString("%1 out of bounds").arg(column).toLocal8Bit());
Q_ASSERT_X(1 <= row && row <= KS_rowMax, __FUNCTION__, QString("%1 out of bounds").arg(row).toLocal8Bit());
m_cellAnchoredShapes[sheet][row].insert(column, shape);
}
bool rowHasCellAnchoredShapes(const Sheet* sheet, int row) const {
AnchoredShapes::const_iterator it = m_cellAnchoredShapes.constFind(sheet);
if (it == m_cellAnchoredShapes.constEnd())
return false;
return (*it).contains(row);
}
bool cellHasAnchoredShapes(const Sheet *sheet, int row, int column) const {
AnchoredShapes::const_iterator it = m_cellAnchoredShapes.constFind(sheet);
if (it == m_cellAnchoredShapes.constEnd())
return false;
AnchoredShape::const_iterator rit = (*it).constFind(row);
if (rit == (*it).constEnd())
return false;
return (*rit).contains(column);
}
int nextAnchoredShape(const Sheet *sheet, int row, int column) const {
AnchoredShapes::const_iterator it = m_cellAnchoredShapes.constFind(sheet);
if (it != m_cellAnchoredShapes.constEnd()) {
AnchoredShape::const_iterator rit = (*it).constFind(row);
if (rit != (*it).constEnd()) {
QMultiHash<int, KoShape*>::const_iterator cit((*rit).constBegin()), cend((*rit).constEnd());
for (; cit != cend; ++cit)
if (cit.key() > column) return cit.key(); // found one
}
}
return 0;
}
QList<KoShape*> cellAnchoredShapes(const Sheet *sheet, int row, int column) const {
AnchoredShapes::const_iterator it = m_cellAnchoredShapes.constFind(sheet);
if (it != m_cellAnchoredShapes.constEnd()) {
AnchoredShape::const_iterator rit = (*it).constFind(row);
if (rit != (*it).constEnd()) {
return (*rit).values(column);
}
}
return QList<KoShape*>();
}
public:
KoShapeSavingContext& shapeContext;
GenValidationStyles valStyle;
QMap<int, Style> columnDefaultStyles;
QMap<int, Style> rowDefaultStyles;
private:
typedef QHash < int /*row*/, QMultiHash < int /*col*/, KoShape* > > AnchoredShape;
typedef QHash < const Sheet*, AnchoredShape > AnchoredShapes;
AnchoredShapes m_cellAnchoredShapes;
};
} // namespace Sheets
} // namespace Calligra
#endif // KSPREAD_ODF_SAVING_CONTEXT
|