init repo

This commit is contained in:
nikolay ivanov
2014-07-05 18:22:49 +00:00
commit a8be6b9e72
17348 changed files with 9229832 additions and 0 deletions

View File

@@ -0,0 +1,905 @@
/*
* (c) Copyright Ascensio System SIA 2010-2014
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
#pragma once
#ifndef OOX_AUTOFILTER_FILE_INCLUDE_H_
#define OOX_AUTOFILTER_FILE_INCLUDE_H_
#include "../CommonInclude.h"
namespace OOX
{
namespace Spreadsheet
{
class CSortCondition : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CSortCondition)
CSortCondition()
{
}
virtual ~CSortCondition()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oDescending.IsInit() || m_oRef.IsInit() || m_oSortBy.IsInit() || m_oDxfId.IsInit())
{
writer.WriteStringC(CString(_T("<sortCondition")));
if(m_oSortBy.IsInit())
{
CString sXml;
sXml.Format(_T(" sortBy=\"%s\""), m_oSortBy->ToString());
writer.WriteStringC(sXml);
}
if(m_oDescending.IsInit())
{
CString sXml;
sXml.Format(_T(" descending=\"%s\""), m_oDescending->ToString2(SimpleTypes::onofftostring1));
writer.WriteStringC(sXml);
}
if(m_oRef.IsInit())
{
CString sXml;
sXml.Format(_T(" ref=\"%s\""), XmlUtils::EncodeXmlString(m_oRef->GetValue()));
writer.WriteStringC(sXml);
}
if(m_oDxfId.IsInit())
{
CString sXml;
sXml.Format(_T(" dxfId=\"%d\""), m_oDxfId->GetValue());
writer.WriteStringC(sXml);
}
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_SortCondition;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("descending"), m_oDescending )
WritingElement_ReadAttributes_Read_if ( oReader, _T("ref"), m_oRef )
WritingElement_ReadAttributes_Read_if ( oReader, _T("sortBy"), m_oSortBy )
WritingElement_ReadAttributes_Read_if ( oReader, _T("dxfId"), m_oDxfId )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::COnOff<> > m_oDescending;
nullable<SimpleTypes::CRelationshipId > m_oRef;
nullable<SimpleTypes::Spreadsheet::CSortBy<> > m_oSortBy;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oDxfId;
};
class CSortState : public WritingElementWithChilds<CSortCondition>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CSortState)
CSortState()
{
}
virtual ~CSortState()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oRef.IsInit() && m_arrItems.GetSize() > 0)
{
CString sXml;
sXml.Format(_T("<sortState ref=\"%s\""), XmlUtils::EncodeXmlString(m_oRef->GetValue()));
if(m_oCaseSensitive.IsInit())
sXml.AppendFormat(_T(" caseSensitive=\"%s\""), m_oCaseSensitive->ToString2(SimpleTypes::onofftostring1));
sXml.Append(_T(">"));
writer.WriteStringC(sXml);
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
writer.WriteStringC(CString(_T("</sortState>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("sortCondition") == sName )
m_arrItems.Add(new CSortCondition(oReader));
}
}
virtual EElementType getType () const
{
return et_SortState;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("ref"), m_oRef )
WritingElement_ReadAttributes_Read_if ( oReader, _T("caseSensitive"), m_oCaseSensitive )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CRelationshipId > m_oRef;
nullable<SimpleTypes::COnOff<> > m_oCaseSensitive;
};
class CColorFilter : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CColorFilter)
CColorFilter()
{
}
virtual ~CColorFilter()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oDxfId.IsInit())
{
CString sXml;
sXml.Format(_T("<colorFilter dxfId=\"%d\""), m_oDxfId->GetValue());
writer.WriteStringC(sXml);
if(m_oCellColor.IsInit() && false == m_oCellColor->ToBool())
writer.WriteStringC(CString(_T(" cellColor=\"0\"")));
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_ColorFilter;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("cellColor"), m_oCellColor )
WritingElement_ReadAttributes_Read_if ( oReader, _T("dxfId"), m_oDxfId )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::COnOff<> > m_oCellColor;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oDxfId;
};
class CDynamicFilter : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CDynamicFilter)
CDynamicFilter()
{
}
virtual ~CDynamicFilter()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oType.IsInit())
{
CString sXml;
sXml.Format(_T("<dynamicFilter type=\"%s\""), m_oType->ToString());
writer.WriteStringC(sXml);
if(m_oVal.IsInit())
{
CString sVal;
sVal.Format(_T(" val=\"%s\""), OOX::Spreadsheet::SpreadsheetCommon::WriteDouble(m_oVal->GetValue()));
writer.WriteStringC(sVal);
}
if(m_oMaxVal.IsInit())
{
CString sVal;
sVal.Format(_T(" maxVal=\"%s\""), OOX::Spreadsheet::SpreadsheetCommon::WriteDouble(m_oMaxVal->GetValue()));
writer.WriteStringC(sVal);
}
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_DynamicFilter;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("type"), m_oType )
WritingElement_ReadAttributes_Read_if ( oReader, _T("val"), m_oVal )
WritingElement_ReadAttributes_Read_if ( oReader, _T("maxVal"), m_oMaxVal )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::Spreadsheet::CDynamicFilterType<> > m_oType;
nullable<SimpleTypes::CDouble > m_oVal;
nullable<SimpleTypes::CDouble > m_oMaxVal;
};
class CCustomFilter : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CCustomFilter)
CCustomFilter()
{
}
virtual ~CCustomFilter()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oOperator.IsInit() && m_oVal.IsInit())
{
CString sXml;
sXml.Format(_T("<customFilter operator=\"%s\" val=\"%s\"/>"), m_oOperator->ToString(), m_oVal.get());
writer.WriteStringC(sXml);
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_CustomFilters;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("operator"), m_oOperator )
WritingElement_ReadAttributes_Read_if ( oReader, _T("val"), m_oVal )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::Spreadsheet::CCustomFilter<> > m_oOperator;
nullable<CString > m_oVal;
};
class CCustomFilters : public WritingElementWithChilds<CCustomFilter>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CCustomFilters)
CCustomFilters()
{
}
virtual ~CCustomFilters()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_arrItems.GetSize() > 0)
{
writer.WriteStringC(CString(_T("<customFilters")));
if(m_oAnd.IsInit() && true == m_oAnd->ToBool())
writer.WriteStringC(CString(_T(" and=\"1\"")));
writer.WriteStringC(CString(_T(">")));
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
writer.WriteStringC(CString(_T("</customFilters>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("customFilter") == sName )
m_arrItems.Add( new CCustomFilter(oReader));
}
}
virtual EElementType getType () const
{
return et_CustomFilters;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("and"), m_oAnd )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::COnOff<> > m_oAnd;
};
class CFilter : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CFilter)
CFilter()
{
}
virtual ~CFilter()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oVal.IsInit())
{
CString sXml;
sXml.Format(_T("<filter val=\"%s\"/>"), XmlUtils::EncodeXmlString(m_oVal.get()));
writer.WriteStringC(sXml);
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_Filter;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("val"), m_oVal )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<CString > m_oVal;
};
class CDateGroupItem : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CDateGroupItem)
CDateGroupItem()
{
}
virtual ~CDateGroupItem()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oDateTimeGrouping.IsInit())
{
writer.WriteStringC(CString(_T("<dateGroupItem")));
if(m_oYear.IsInit())
{
CString sXml;
sXml.Format(_T(" year=\"%d\""), m_oYear->GetValue());
writer.WriteStringC(sXml);
}
if(m_oMonth.IsInit())
{
CString sXml;
sXml.Format(_T(" month=\"%d\""), m_oMonth->GetValue());
writer.WriteStringC(sXml);
}
if(m_oDay.IsInit())
{
CString sXml;
sXml.Format(_T(" day=\"%d\""), m_oDay->GetValue());
writer.WriteStringC(sXml);
}
if(m_oHour.IsInit())
{
CString sXml;
sXml.Format(_T(" hour=\"%d\""), m_oHour->GetValue());
writer.WriteStringC(sXml);
}
if(m_oMinute.IsInit())
{
CString sXml;
sXml.Format(_T(" minute=\"%d\""), m_oMinute->GetValue());
writer.WriteStringC(sXml);
}
if(m_oSecond.IsInit())
{
CString sXml;
sXml.Format(_T(" second=\"%d\""), m_oSecond->GetValue());
writer.WriteStringC(sXml);
}
if(m_oDateTimeGrouping.IsInit())
{
CString sXml;
sXml.Format(_T(" dateTimeGrouping=\"%s\""), m_oDateTimeGrouping->ToString());
writer.WriteStringC(sXml);
}
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_DateGroupItem;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("dateTimeGrouping"), m_oDateTimeGrouping )
WritingElement_ReadAttributes_Read_if ( oReader, _T("day"), m_oDay )
WritingElement_ReadAttributes_Read_if ( oReader, _T("hour"), m_oHour )
WritingElement_ReadAttributes_Read_if ( oReader, _T("minute"), m_oMinute )
WritingElement_ReadAttributes_Read_if ( oReader, _T("month"), m_oMonth )
WritingElement_ReadAttributes_Read_if ( oReader, _T("second"), m_oSecond )
WritingElement_ReadAttributes_Read_if ( oReader, _T("year"), m_oYear )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::Spreadsheet::CDateTimeGroup<> > m_oDateTimeGrouping;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oDay;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oHour;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oMinute;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oMonth;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oSecond;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oYear;
};
class CFilters : public WritingElementWithChilds<>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CFilters)
CFilters()
{
}
virtual ~CFilters()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_arrItems.GetSize() > 0)
{
writer.WriteStringC(_T("<filters"));
if(m_oBlank.IsInit())
{
CString sXml;
sXml.Format(_T(" blank=\"%s\""), m_oBlank->ToString2(SimpleTypes::onofftostring1));
writer.WriteStringC(sXml);
}
writer.WriteStringC(_T(">"));
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
writer.WriteStringC(_T("</filters>"));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("dateGroupItem") == sName )
m_arrItems.Add( new CDateGroupItem(oReader));
if ( _T("filter") == sName )
m_arrItems.Add( new CFilter(oReader));
}
}
virtual EElementType getType () const
{
return et_Filters;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("blank"), m_oBlank )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::COnOff<> > m_oBlank;
};
class CTop10 : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTop10)
CTop10()
{
}
virtual ~CTop10()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oVal.IsInit())
{
writer.WriteStringC(CString(_T("<top10")));
if(m_oTop.IsInit() && false == m_oTop->ToBool())
writer.WriteStringC(CString(_T(" top=\"0\"")));
if(m_oPercent.IsInit() && true == m_oPercent->ToBool())
writer.WriteStringC(CString(_T(" percent=\"1\"")));
if(m_oVal.IsInit())
{
CString sXml;
sXml.Format(_T(" val=\"%s\""), OOX::Spreadsheet::SpreadsheetCommon::WriteDouble(m_oVal->GetValue()));
writer.WriteStringC(sXml);
}
if(m_oFilterVal.IsInit())
{
CString sXml;
sXml.Format(_T(" filterVal=\"%s\""), OOX::Spreadsheet::SpreadsheetCommon::WriteDouble(m_oFilterVal->GetValue()));
writer.WriteStringC(sXml);
}
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_ColorFilter;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("filterVal"), m_oFilterVal )
WritingElement_ReadAttributes_Read_if ( oReader, _T("percent"), m_oPercent )
WritingElement_ReadAttributes_Read_if ( oReader, _T("top"), m_oTop )
WritingElement_ReadAttributes_Read_if ( oReader, _T("val"), m_oVal )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CDouble > m_oFilterVal;
nullable<SimpleTypes::COnOff<> > m_oPercent;
nullable<SimpleTypes::COnOff<> > m_oTop;
nullable<SimpleTypes::CDouble > m_oVal;
};
class CFilterColumn : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CFilterColumn)
CFilterColumn()
{
}
virtual ~CFilterColumn()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oColId.IsInit() && (m_oColorFilter.IsInit() || m_oDynamicFilter.IsInit() || m_oCustomFilters.IsInit() || m_oFilters.IsInit() ||
m_oTop10.IsInit() || m_oShowButton.IsInit() || m_oHiddenButton.IsInit()))
{
CString sXml;
sXml.Format(_T("<filterColumn colId=\"%d\""), m_oColId->GetValue());
writer.WriteStringC(sXml);
if(m_oShowButton.IsInit() && false == m_oShowButton->ToBool())
writer.WriteStringC(CString(_T(" showButton=\"0\"")));
if(m_oHiddenButton.IsInit())
{
CString sXml;sXml.Format(_T(" hiddenButton=\"%s\""), m_oHiddenButton->ToString2(SimpleTypes::onofftostring1));
writer.WriteStringC(sXml);
}
writer.WriteStringC(CString(_T(">")));
if(m_oColorFilter.IsInit())
m_oColorFilter->toXML(writer);
if(m_oDynamicFilter.IsInit())
m_oDynamicFilter->toXML(writer);
if(m_oCustomFilters.IsInit())
m_oCustomFilters->toXML(writer);
if(m_oFilters.IsInit())
m_oFilters->toXML(writer);
if(m_oTop10.IsInit())
m_oTop10->toXML(writer);
writer.WriteStringC(CString(_T("</filterColumn>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("colorFilter") == sName )
m_oColorFilter = oReader;
else if ( _T("dynamicFilter") == sName )
m_oDynamicFilter = oReader;
else if ( _T("customFilters") == sName )
m_oCustomFilters = oReader;
else if ( _T("filters") == sName )
m_oFilters = oReader;
else if ( _T("top10") == sName )
m_oTop10 = oReader;
}
}
virtual EElementType getType () const
{
return et_FilterColumn;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("colId"), m_oColId )
WritingElement_ReadAttributes_Read_if ( oReader, _T("hiddenButton"), m_oHiddenButton )
WritingElement_ReadAttributes_Read_if ( oReader, _T("showButton"), m_oShowButton )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oColId;
nullable<SimpleTypes::COnOff<> > m_oHiddenButton;
nullable<SimpleTypes::COnOff<> > m_oShowButton;
nullable<CColorFilter > m_oColorFilter;
nullable<CDynamicFilter > m_oDynamicFilter;
nullable<CCustomFilters > m_oCustomFilters;
nullable<CFilters > m_oFilters;
nullable<CTop10 > m_oTop10;
};
class CAutofilter : public WritingElementWithChilds<CFilterColumn>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CAutofilter)
CAutofilter()
{
}
virtual ~CAutofilter()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oRef.IsInit())
{
CString sXml;
sXml.Format(_T("<autoFilter ref=\"%s\">"), XmlUtils::EncodeXmlString(m_oRef->GetValue()));
writer.WriteStringC(sXml);
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
if(m_oSortState.IsInit())
m_oSortState->toXML(writer);
writer.WriteStringC(CString(_T("</autoFilter>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("filterColumn") == sName )
m_arrItems.Add(new CFilterColumn(oReader));
else if ( _T("sortState") == sName )
m_oSortState = oReader;
}
}
virtual EElementType getType () const
{
return et_Autofilter;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("ref"), m_oRef )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CRelationshipId > m_oRef;
nullable<CSortState > m_oSortState;
};
}
}
#endif // OOX_AUTOFILTER_FILE_INCLUDE_H_

View File

@@ -0,0 +1,588 @@
/*
* (c) Copyright Ascensio System SIA 2010-2014
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
#pragma once
#ifndef OOX_TABLE_FILE_INCLUDE_H_
#define OOX_TABLE_FILE_INCLUDE_H_
#include "../CommonInclude.h"
#include "Autofilter.h"
namespace OOX
{
namespace Spreadsheet
{
class CTableStyleInfo : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTableStyleInfo)
CTableStyleInfo()
{
}
virtual ~CTableStyleInfo()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oName.IsInit())
{
int nShowColumnStripes = 0;
int nShowFirstColumn = 0;
int nShowLastColumn = 0;
int nShowRowStripes = 0;
if(m_oShowColumnStripes.IsInit() && true == m_oShowColumnStripes->ToBool())
nShowColumnStripes = 1;
if(m_oShowFirstColumn.IsInit() && true == m_oShowFirstColumn->ToBool())
nShowFirstColumn = 1;
if(m_oShowLastColumn.IsInit() && true == m_oShowLastColumn->ToBool())
nShowLastColumn = 1;
if(m_oShowRowStripes.IsInit() && true == m_oShowRowStripes->ToBool())
nShowRowStripes = 1;
CString sXml;
sXml.Format(_T("<tableStyleInfo name=\"%s\" showFirstColumn=\"%d\" showLastColumn=\"%d\" showRowStripes=\"%d\" showColumnStripes=\"%d\"/>"), XmlUtils::EncodeXmlString(m_oName.get()), nShowFirstColumn, nShowLastColumn, nShowRowStripes, nShowColumnStripes);
writer.WriteStringC(sXml);
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_TableStyleInfo;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("name"), m_oName )
WritingElement_ReadAttributes_Read_if ( oReader, _T("showColumnStripes"), m_oShowColumnStripes )
WritingElement_ReadAttributes_Read_if ( oReader, _T("showFirstColumn"), m_oShowFirstColumn )
WritingElement_ReadAttributes_Read_if ( oReader, _T("showLastColumn"), m_oShowLastColumn )
WritingElement_ReadAttributes_Read_if ( oReader, _T("showRowStripes"), m_oShowRowStripes )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<CString > m_oName;
nullable<SimpleTypes::COnOff<> > m_oShowColumnStripes;
nullable<SimpleTypes::COnOff<> > m_oShowFirstColumn;
nullable<SimpleTypes::COnOff<> > m_oShowLastColumn;
nullable<SimpleTypes::COnOff<> > m_oShowRowStripes;
};
class CTableColumn : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTableColumn)
CTableColumn()
{
}
virtual ~CTableColumn()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
CString sRoot;
writer.WriteStringC(CString(_T("<tableColumn")));
if(m_oId.IsInit())
{
CString sXml;
sXml.Format(_T(" id=\"%d\""), m_oId->GetValue());
writer.WriteStringC(sXml);
}
if(m_oName.IsInit())
{
CString sXml;
sXml.Format(_T(" name=\"%s\""), XmlUtils::EncodeXmlString(m_oName.get()));
writer.WriteStringC(sXml);
}
if(m_oTotalsRowLabel.IsInit())
{
CString sXml;
sXml.Format(_T(" totalsRowLabel=\"%s\""), XmlUtils::EncodeXmlString(m_oTotalsRowLabel.get()));
writer.WriteStringC(sXml);
}
if(m_oTotalsRowFunction.IsInit())
{
CString sXml;
sXml.Format(_T(" totalsRowFunction=\"%s\""), m_oTotalsRowFunction->ToString());
writer.WriteStringC(sXml);
}
if(m_oDataDxfId.IsInit())
{
CString sXml;
sXml.Format(_T(" dataDxfId=\"%d\""), m_oDataDxfId->GetValue());
writer.WriteStringC(sXml);
}
if(m_oTotalsRowFormula.IsInit() || m_oCalculatedColumnFormula.IsInit())
{
writer.WriteStringC(CString(_T(">")));
if(m_oTotalsRowFormula.IsInit())
{
CString sXml;
sXml.Format(_T("<totalsRowFormula>%s</totalsRowFormula>"), XmlUtils::EncodeXmlString(m_oTotalsRowFormula.get()));
writer.WriteStringC(sXml);
}
if(m_oCalculatedColumnFormula.IsInit())
{
CString sXml;
sXml.Format(_T("<calculatedColumnFormula>%s</calculatedColumnFormula>"), XmlUtils::EncodeXmlString(m_oCalculatedColumnFormula.get()));
writer.WriteStringC(sXml);
}
writer.WriteStringC(CString(_T("</tableColumn>")));
}
else
{
writer.WriteStringC(CString(_T("/>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("totalsRowFormula") == sName )
m_oTotalsRowFormula = oReader.GetText2();
else if ( _T("calculatedColumnFormula") == sName )
m_oCalculatedColumnFormula = oReader.GetText2();
}
}
virtual EElementType getType () const
{
return et_TableColumn;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("id"), m_oId )
WritingElement_ReadAttributes_Read_if ( oReader, _T("name"), m_oName )
WritingElement_ReadAttributes_Read_if ( oReader, _T("totalsRowLabel"), m_oTotalsRowLabel )
WritingElement_ReadAttributes_Read_if ( oReader, _T("totalsRowFunction"), m_oTotalsRowFunction )
WritingElement_ReadAttributes_Read_if ( oReader, _T("dataDxfId"), m_oDataDxfId )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oId;
nullable<CString > m_oName;
nullable<CString > m_oTotalsRowLabel;
nullable<SimpleTypes::Spreadsheet::CTotalsRowFunction<> > m_oTotalsRowFunction;
nullable<CString > m_oTotalsRowFormula;
nullable<CString > m_oCalculatedColumnFormula;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oDataDxfId;
};
class CTableColumns : public WritingElementWithChilds<CTableColumn>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTableColumns)
CTableColumns()
{
}
virtual ~CTableColumns()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_arrItems.GetSize() > 0)
{
CString sRoot;
sRoot.Format(_T("<tableColumns count=\"%d\">"), m_arrItems.GetSize());
writer.WriteStringC(sRoot);
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
writer.WriteStringC(CString(_T("</tableColumns>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("tableColumn") == sName )
m_arrItems.Add(new CTableColumn(oReader));
}
}
virtual EElementType getType () const
{
return et_TableColumns;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("count"), m_oCount )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oCount;
};
class CTable : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTable)
CTable()
{
}
virtual ~CTable()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
}
virtual void toXML2(CStringWriter& writer, int nIndex) const
{
if(m_oRef.IsInit() && m_oDisplayName.IsInit())
{
CString sRoot;
sRoot.Format(_T("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?><table xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" id=\"%d\" name=\"%s\" displayName=\"%s\" ref=\"%s\""), nIndex, m_oDisplayName.get(), m_oDisplayName.get(), m_oRef->GetValue());
writer.WriteStringC(sRoot);
if(m_oHeaderRowCount.IsInit() && 0 == m_oHeaderRowCount->GetValue())
writer.WriteStringC(CString(_T(" headerRowCount=\"0\"")));
if(m_oTotalsRowCount.IsInit() && m_oTotalsRowCount->GetValue() > 0)
writer.WriteStringC(CString(_T(" totalsRowCount=\"1\"")));
else
writer.WriteStringC(CString(_T(" totalsRowShown=\"0\"")));
writer.WriteStringC(CString(_T(">")));
if(m_oAutoFilter.IsInit())
m_oAutoFilter->toXML(writer);
if(m_oSortState.IsInit())
m_oSortState->toXML(writer);
if(m_oTableColumns.IsInit())
m_oTableColumns->toXML(writer);
if(m_oTableStyleInfo.IsInit())
m_oTableStyleInfo->toXML(writer);
writer.WriteStringC(_T("</table>"));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("autoFilter") == sName )
m_oAutoFilter = oReader;
else if ( _T("sortState") == sName )
m_oSortState = oReader;
else if ( _T("tableColumns") == sName )
m_oTableColumns = oReader;
else if ( _T("tableStyleInfo") == sName )
m_oTableStyleInfo = oReader;
}
}
virtual EElementType getType () const
{
return et_Table;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("ref"), m_oRef )
WritingElement_ReadAttributes_Read_if ( oReader, _T("headerRowCount"), m_oHeaderRowCount )
WritingElement_ReadAttributes_Read_if ( oReader, _T("totalsRowCount"), m_oTotalsRowCount )
WritingElement_ReadAttributes_Read_if ( oReader, _T("displayName"), m_oDisplayName )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CRelationshipId > m_oRef;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oHeaderRowCount;
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oTotalsRowCount;
nullable<CString > m_oDisplayName;
nullable<CAutofilter > m_oAutoFilter;
nullable<CSortState > m_oSortState;
nullable<CTableColumns > m_oTableColumns;
nullable<CTableStyleInfo > m_oTableStyleInfo;
};
class CTablePart : public WritingElement
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTablePart)
CTablePart()
{
}
virtual ~CTablePart()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_oRId.IsInit())
{
CString sXml;
sXml.Format(_T("<tablePart r:id=\"%s\"/>"), m_oRId->GetValue());
writer.WriteStringC(sXml);
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( !oReader.IsEmptyNode() )
oReader.ReadTillEnd();
}
virtual EElementType getType () const
{
return et_TablePart;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("r:id"), m_oRId )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CRelationshipId > m_oRId;
};
class CTableParts : public WritingElementWithChilds<CTablePart>
{
public:
WritingElementSpreadsheet_AdditionConstructors(CTableParts)
CTableParts()
{
}
virtual ~CTableParts()
{
}
public:
virtual CString toXML() const
{
return _T("");
}
virtual void toXML(CStringWriter& writer) const
{
if(m_arrItems.GetSize() > 0)
{
CString sXml;
sXml.Format(_T("<tableParts count=\"%d\">"), m_arrItems.GetSize());
writer.WriteStringC(sXml);
for(int i = 0, length = m_arrItems.GetSize(); i < length; ++i)
m_arrItems[i]->toXML(writer);
writer.WriteStringC(CString(_T("</tableParts>")));
}
}
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
{
ReadAttributes( oReader );
if ( oReader.IsEmptyNode() )
return;
int nCurDepth = oReader.GetDepth();
while( oReader.ReadNextSiblingNode( nCurDepth ) )
{
CWCharWrapper sName = oReader.GetName();
if ( _T("tablePart") == sName )
m_arrItems.Add(new CTablePart(oReader));
}
}
virtual EElementType getType () const
{
return et_TableParts;
}
private:
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
WritingElement_ReadAttributes_Start( oReader )
WritingElement_ReadAttributes_Read_if ( oReader, _T("count"), m_oCount )
WritingElement_ReadAttributes_End( oReader )
}
public:
nullable<SimpleTypes::CUnsignedDecimalNumber<> > m_oCount;
};
class CTableFile : public OOX::FileGlobalEnumerated, public OOX::Spreadsheet::IFileContainer
{
public:
CTableFile()
{
}
CTableFile(const CPath& oPath)
{
read( oPath );
}
virtual ~CTableFile()
{
}
public:
virtual void read(const CPath& oPath)
{
m_oReadPath = oPath;
IFileContainer::Read( oPath );
XmlUtils::CXmlLiteReader oReader;
if ( !oReader.FromFile( oPath.GetPath() ) )
return;
if ( !oReader.ReadNextNode() )
return;
m_oTable = oReader;
}
virtual void write(const CPath& oPath, const CPath& oDirectory, CContentTypes& oContent) const
{
if(m_oTable.IsInit())
{
CStringWriter sXml;
int nGlobalNumber = OOX::FileGlobalEnumerated::GetGlobalNumber();
m_oTable->toXML2(sXml, nGlobalNumber);
CDirectory::SaveToFile( oPath.GetPath(), sXml.GetCString() );
oContent.Registration( type().OverrideType(), oDirectory, oPath.GetFilename() );
IFileContainer::Write( oPath, oDirectory, oContent );
}
}
virtual const OOX::FileType type() const
{
return OOX::Spreadsheet::FileTypes::Table;
}
virtual const CPath DefaultDirectory() const
{
return type().DefaultDirectory();
}
virtual const CPath DefaultFileName() const
{
return type().DefaultFileName();
}
const CPath& GetReadPath()
{
return m_oReadPath;
}
private:
CPath m_oReadPath;
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
{
}
public:
nullable<CTable> m_oTable;
};
}
}
#endif // OOX_TABLE_FILE_INCLUDE_H_