|
|
|
/****************************************************************************
|
|
|
|
** Copyright (c) 2013 Debao Zhang <hello@debao.me>
|
|
|
|
** All right reserved.
|
|
|
|
**
|
|
|
|
** Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
** a copy of this software and associated documentation files (the
|
|
|
|
** "Software"), to deal in the Software without restriction, including
|
|
|
|
** without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
** distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
** permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
** the following conditions:
|
|
|
|
**
|
|
|
|
** The above copyright notice and this permission notice shall be
|
|
|
|
** included in all copies or substantial portions of the Software.
|
|
|
|
**
|
|
|
|
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
** NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
|
|
** LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
|
|
** OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
** WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
#ifndef XLSXFORMAT_P_H
|
|
|
|
#define XLSXFORMAT_P_H
|
|
|
|
#include "xlsxformat.h"
|
|
|
|
#include <QSharedData>
|
|
|
|
#include <QHash>
|
|
|
|
|
|
|
|
namespace QXlsx {
|
|
|
|
|
|
|
|
struct XlsxFormatAlignmentData
|
|
|
|
{
|
|
|
|
XlsxFormatAlignmentData() :
|
|
|
|
alignH(Format::AlignHGeneral), alignV(Format::AlignBottom)
|
|
|
|
, wrap(false), rotation(0), indent(0), shinkToFit(false)
|
|
|
|
{}
|
|
|
|
|
|
|
|
Format::HorizontalAlignment alignH;
|
|
|
|
Format::VerticalAlignment alignV;
|
|
|
|
bool wrap;
|
|
|
|
int rotation;
|
|
|
|
int indent;
|
|
|
|
bool shinkToFit;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct XlsxFormatFillData {
|
|
|
|
XlsxFormatFillData() :
|
|
|
|
pattern(Format::PatternNone)
|
|
|
|
,_dirty(true), _indexValid(false), _index(-1)
|
|
|
|
{}
|
|
|
|
|
|
|
|
Format::FillPattern pattern;
|
|
|
|
QColor bgColor;
|
|
|
|
QColor fgColor;
|
|
|
|
QString bgThemeColor;
|
|
|
|
QString fgThemeColor;
|
|
|
|
|
|
|
|
QByteArray key() const
|
|
|
|
{
|
|
|
|
if (_dirty) {
|
|
|
|
QByteArray key;
|
|
|
|
QDataStream stream(&key, QIODevice::WriteOnly);
|
|
|
|
stream<< bgColor << bgThemeColor
|
|
|
|
<< fgColor << fgThemeColor
|
|
|
|
<< pattern;
|
|
|
|
const_cast<XlsxFormatFillData*>(this)->_key = key;
|
|
|
|
const_cast<XlsxFormatFillData*>(this)->_dirty = false;
|
|
|
|
const_cast<XlsxFormatFillData*>(this)->_indexValid = false;
|
|
|
|
}
|
|
|
|
return _key;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool indexValid() const
|
|
|
|
{
|
|
|
|
return !_dirty && _indexValid;
|
|
|
|
}
|
|
|
|
|
|
|
|
int index() const
|
|
|
|
{
|
|
|
|
return _index;
|
|
|
|
}
|
|
|
|
|
|
|
|
void setIndex(int index)
|
|
|
|
{
|
|
|
|
_index = index;
|
|
|
|
_indexValid = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//helper member
|
|
|
|
bool _dirty; //key re-generated and proper index assign is need.
|
|
|
|
|
|
|
|
private:
|
|
|
|
QByteArray _key;
|
|
|
|
bool _indexValid; //has a valid index, so no need to assign a new one
|
|
|
|
int _index; //index in the border list
|
|
|
|
};
|
|
|
|
|
|
|
|
struct XlsxFormatProtectionData {
|
|
|
|
XlsxFormatProtectionData() :
|
|
|
|
locked(false), hidden(false)
|
|
|
|
{}
|
|
|
|
|
|
|
|
bool locked;
|
|
|
|
bool hidden;
|
|
|
|
};
|
|
|
|
|
|
|
|
class FormatPrivate : public QSharedData
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum FormatType
|
|
|
|
{
|
|
|
|
FT_Invalid = 0,
|
|
|
|
FT_NumFmt = 0x01,
|
|
|
|
FT_Font = 0x02,
|
|
|
|
FT_Alignment = 0x04,
|
|
|
|
FT_Border = 0x08,
|
|
|
|
FT_Fill = 0x10,
|
|
|
|
FT_Protection = 0x20
|
|
|
|
};
|
|
|
|
|
|
|
|
enum Property {
|
|
|
|
//numFmt
|
|
|
|
P_NumFmt_Id,
|
|
|
|
P_NumFmt_FormatCode,
|
|
|
|
|
|
|
|
//font
|
|
|
|
P_Font_STARTID,
|
|
|
|
P_Font_Size = P_Font_STARTID,
|
|
|
|
P_Font_Italic,
|
|
|
|
P_Font_StrikeOut,
|
|
|
|
P_Font_Color,
|
|
|
|
P_Font_ThemeColor,
|
|
|
|
P_Font_Bold,
|
|
|
|
P_Font_Script,
|
|
|
|
P_Font_Underline,
|
|
|
|
P_Font_Outline,
|
|
|
|
P_Font_Shadow,
|
|
|
|
P_Font_Name,
|
|
|
|
P_Font_Family,
|
|
|
|
P_Font_Charset,
|
|
|
|
P_Font_Scheme,
|
|
|
|
P_Font_Condense,
|
|
|
|
P_Font_Extend,
|
|
|
|
P_Font_ENDID,
|
|
|
|
|
|
|
|
//border
|
|
|
|
P_Border_STARTID,
|
|
|
|
P_Border_LeftStyle = P_Border_STARTID,
|
|
|
|
P_Border_RightStyle,
|
|
|
|
P_Border_TopStyle,
|
|
|
|
P_Border_BottomStyle,
|
|
|
|
P_Border_DiagonalStyle,
|
|
|
|
P_Border_LeftColor,
|
|
|
|
P_Border_RightColor,
|
|
|
|
P_Border_TopColor,
|
|
|
|
P_Border_BottomColor,
|
|
|
|
P_Border_DiagonalColor,
|
|
|
|
P_Border_DiagonalType,
|
|
|
|
P_Border_ThemeLeftColor,
|
|
|
|
P_Border_ThemeRightColor,
|
|
|
|
P_Border_ThemeTopColor,
|
|
|
|
P_Border_ThemeBottomColor,
|
|
|
|
P_Border_ThemeDiagonalColor,
|
|
|
|
P_Border_ENDID,
|
|
|
|
|
|
|
|
//fill
|
|
|
|
P_Fill_,
|
|
|
|
|
|
|
|
//alignment
|
|
|
|
P_Alignment_,
|
|
|
|
|
|
|
|
//protection
|
|
|
|
P_Protection_,
|
|
|
|
};
|
|
|
|
|
|
|
|
FormatPrivate();
|
|
|
|
FormatPrivate(const FormatPrivate &other);
|
|
|
|
~FormatPrivate();
|
|
|
|
|
|
|
|
XlsxFormatAlignmentData alignmentData;
|
|
|
|
XlsxFormatFillData fillData;
|
|
|
|
XlsxFormatProtectionData protectionData;
|
|
|
|
|
|
|
|
bool dirty; //The key re-generation is need.
|
|
|
|
QByteArray formatKey;
|
|
|
|
|
|
|
|
bool font_dirty;
|
|
|
|
bool font_index_valid;
|
|
|
|
QByteArray font_key;
|
|
|
|
int font_index;
|
|
|
|
|
|
|
|
bool border_dirty;
|
|
|
|
bool border_index_valid;
|
|
|
|
QByteArray border_key;
|
|
|
|
int border_index;
|
|
|
|
|
|
|
|
int xf_index;
|
|
|
|
bool xf_indexValid;
|
|
|
|
|
|
|
|
bool is_dxf_fomat;
|
|
|
|
int dxf_index;
|
|
|
|
bool dxf_indexValid;
|
|
|
|
|
|
|
|
int theme;
|
|
|
|
|
|
|
|
QHash<int, QVariant> property;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // XLSXFORMAT_P_H
|