/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: txtflde.hxx,v $ * * $Revision: 1.31 $ * * last change: $Author: hr $ $Date: 2006-06-19 17:56:31 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ /** @#file * XML export of all text fields */ #ifndef _XMLOFF_TXTFLDE_HXX #define _XMLOFF_TXTFLDE_HXX #ifndef _COM_SUN_STAR_UNO_REFERENCE_H_ #include #endif #ifndef _XMLOFF_XMLNMSPE_HXX #include "xmlnmspe.hxx" #endif #ifndef _RTL_USTRING #include #endif #ifndef _XMLOFF_XMLTOKEN_HXX #include "xmltoken.hxx" #endif #include #include class SvXMLExport; class SvXMLNumFmtExport; struct XMLPropertyState; namespace com { namespace sun { namespace star { namespace util { struct DateTime; } namespace util { struct Date; } namespace text { class XTextField; } namespace text { class XText; } namespace beans { class XPropertySet; } namespace beans { class XPropertySetInfo; } namespace frame { class XModel; } namespace uno { template class Sequence; } } } } namespace rtl { class OUString; } /// field IDs, // including translation between UNO speak and XML speak if appropriate enum FieldIdEnum { FIELD_ID_SENDER, // sender == extended user FIELD_ID_AUTHOR, FIELD_ID_DATE, // current date FIELD_ID_TIME, // current time (+date) FIELD_ID_PAGENUMBER, // page number FIELD_ID_PAGESTRING, // page contination string (page number string) FIELD_ID_REFPAGE_SET, // set reference page FIELD_ID_REFPAGE_GET, // get reference page number FIELD_ID_PLACEHOLDER, // placeholder field == jump edit field FIELD_ID_VARIABLE_DECL, // field type for set variable FIELD_ID_VARIABLE_GET, // get variable == get expression FIELD_ID_VARIABLE_SET, // set variable == set expression FIELD_ID_VARIABLE_INPUT, // input field (variable) FIELD_ID_USER_DECL, // field type for user field FIELD_ID_USER_GET, // user field FIELD_ID_USER_INPUT, // input field (user field) FIELD_ID_TEXT_INPUT, // input field (text) FIELD_ID_EXPRESSION, // expression field = formula field FIELD_ID_SEQUENCE_DECL, // field type for sequence FIELD_ID_SEQUENCE, // sequence field FIELD_ID_DATABASE_NEXT, // select next row FIELD_ID_DATABASE_SELECT, // select row # (NumSet) FIELD_ID_DATABASE_DISPLAY, // display data (form letter field) FIELD_ID_DATABASE_NAME, // display current db name (database name) FIELD_ID_DATABASE_NUMBER, // display row # (SetNumber) FIELD_ID_DOCINFO_CREATION_AUTHOR, // docinfo fields FIELD_ID_DOCINFO_CREATION_TIME, FIELD_ID_DOCINFO_CREATION_DATE, FIELD_ID_DOCINFO_DESCRIPTION, FIELD_ID_DOCINFO_INFORMATION0, // ATTENTION: INFO-fields must be numbered FIELD_ID_DOCINFO_INFORMATION1, // consecutively (to find out FIELD_ID_DOCINFO_INFORMATION2, // number) FIELD_ID_DOCINFO_INFORMATION3, FIELD_ID_DOCINFO_PRINT_TIME, FIELD_ID_DOCINFO_PRINT_DATE, FIELD_ID_DOCINFO_PRINT_AUTHOR, FIELD_ID_DOCINFO_TITLE, FIELD_ID_DOCINFO_SUBJECT, FIELD_ID_DOCINFO_KEYWORDS, FIELD_ID_DOCINFO_REVISION, FIELD_ID_DOCINFO_EDIT_DURATION, FIELD_ID_DOCINFO_SAVE_TIME, FIELD_ID_DOCINFO_SAVE_DATE, FIELD_ID_DOCINFO_SAVE_AUTHOR, FIELD_ID_CONDITIONAL_TEXT, // conditionally choose between 2 texts FIELD_ID_HIDDEN_TEXT, // conditionally hide a text FIELD_ID_HIDDEN_PARAGRAPH, // conditionally hide a paragraph FIELD_ID_TEMPLATE_NAME, // display name of template FIELD_ID_CHAPTER, // display name/number of current chapter FIELD_ID_FILE_NAME, // display name of current file FIELD_ID_COUNT_PARAGRAPHS, // statistics fields: - paragraphs FIELD_ID_COUNT_WORDS, // - words FIELD_ID_COUNT_CHARACTERS, // - chars FIELD_ID_COUNT_PAGES, // - pages FIELD_ID_COUNT_TABLES, // - tables FIELD_ID_COUNT_GRAPHICS, // - graphics FIELD_ID_COUNT_OBJECTS, // - objects FIELD_ID_MACRO, // macro fields FIELD_ID_REF_REFERENCE, // get reference field (reference) FIELD_ID_REF_SEQUENCE, // get reference field (sequence) FIELD_ID_REF_BOOKMARK, // get reference field (bookmark) FIELD_ID_REF_FOOTNOTE, // get reference field (footnote) FIELD_ID_REF_ENDNOTE, // get reference field (endnote) FIELD_ID_DDE, // DDE field FIELD_ID_BIBLIOGRAPHY, // bibliography index entry FIELD_ID_SHEET_NAME, // name of current (spread-)sheet FIELD_ID_URL, // URL field (only Calc, Draw, Impress) FIELD_ID_SCRIPT, // script fields (for HTML pages, mostly) FIELD_ID_ANNOTATION, // annotation (notice) field FIELD_ID_COMBINED_CHARACTERS, // combined characters (asian typography) FIELD_ID_MEASURE, // for measure shapes FIELD_ID_TABLE_FORMULA, // DEPRECATED: table formulas (Writer 2.0) FIELD_ID_DROP_DOWN, // DEPRECATED: dropdown fields (WW8) FIELD_ID_DRAW_HEADER, FIELD_ID_DRAW_FOOTER, FIELD_ID_DRAW_DATE_TIME, FIELD_ID_UNKNOWN // invalid or unknown field type! }; class XMLTextFieldExport { SvXMLExport& rExport; /// store used text field master names (NULL means: don't collect) ::std::map< ::com::sun::star::uno::Reference< ::com::sun::star::text::XText >, ::std::set< ::rtl::OUString > > * pUsedMasters; public: XMLTextFieldExport( SvXMLExport& rExp, /// XMLPropertyState for the combined characters field XMLPropertyState* pCombinedCharState = NULL ); virtual ~XMLTextFieldExport(); /// Export this field and the surrounding span element with the formatting. /// To be called for every field in the document body. void ExportField(const ::com::sun::star::uno::Reference < ::com::sun::star::text::XTextField > & rTextField ); /// collect styles (character styles, data styles, ...) for this field /// (if appropriate). /// Also collect used field masters (if pUsedMasters is set) /// to be called for every field during style export. void ExportFieldAutoStyle(const ::com::sun::star::uno::Reference < ::com::sun::star::text::XTextField > & rTextField ); /// export field declarations. /// to be called once at beginning of document body. void ExportFieldDeclarations(); /// export field declarations for fields used in the the particular XText. /// (Requires that a list of used field declarations has previously been /// built-up in ExportFieldAutoStyle() ) void ExportFieldDeclarations( const ::com::sun::star::uno::Reference < ::com::sun::star::text::XText > & rText); /// export all field declarations, or only those that have been used? /// Calling this method will reset the list of used field declataions. void SetExportOnlyUsedFieldDeclarations( sal_Bool bExportOnlyUsed = sal_True); // determine element or attribute names // (public, because they may be useful in related XML export classes) static enum ::xmloff::token::XMLTokenEnum MapPlaceholderType(sal_uInt16 nType); static enum ::xmloff::token::XMLTokenEnum MapTemplateDisplayFormat(sal_Int16 nType); static enum ::xmloff::token::XMLTokenEnum MapChapterDisplayFormat(sal_Int16 nType); static enum ::xmloff::token::XMLTokenEnum MapFilenameDisplayFormat(sal_Int16 nType); static enum ::xmloff::token::XMLTokenEnum MapDocInfoFieldName(enum FieldIdEnum nToken); static enum ::xmloff::token::XMLTokenEnum MapReferenceSource(sal_Int16 nType); static enum ::xmloff::token::XMLTokenEnum MapReferenceType(sal_Int16 nType); static enum ::xmloff::token::XMLTokenEnum MapCountFieldName(sal_Int16 nToken); static enum ::xmloff::token::XMLTokenEnum MapBibliographyFieldName(::rtl::OUString sName); static enum ::xmloff::token::XMLTokenEnum MapMeasureKind(sal_Int16 nKind); enum ::xmloff::token::XMLTokenEnum MapPageNumberName(const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & xPropSet, sal_Int32& nOffset); /// also adjust page offset enum ::xmloff::token::XMLTokenEnum MapAuthorFieldName(const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & xPropSet); enum ::xmloff::token::XMLTokenEnum MapSenderFieldName(const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & xPropSet); protected: SvXMLExport& GetExport() { return rExport; } /// export a field after is already written void ExportFieldHelper( const ::com::sun::star::uno::Reference< ::com::sun::star::text::XTextField> & rTextField, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & rPropSet, const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & rRangePropSet, enum FieldIdEnum nToken); /// export an empty element void ExportElement(enum ::xmloff::token::XMLTokenEnum eElement, /// element token sal_Bool bAddSpace = sal_False); /// add blanks around /// element? /// export an element with string content void ExportElement(enum ::xmloff::token::XMLTokenEnum eElement, /// element token const ::rtl::OUString& sContent, /// element content sal_Bool bAddSpace = sal_False); /// add blanks around /// element? /// export a macro (as used in the macro field) void ExportMacro( const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & rPropSet, const ::rtl::OUString& rContent); /// export a boolean attribute void ProcessBoolean( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) sal_Bool bBool, /// attribute value sal_Bool bDefault); /// attribute default; omit, if attribute differs /// export an integer attribute void ProcessInteger( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) sal_Int32 nNum); /// attribute value /// export an integer attribute, omit if default void ProcessIntegerDef( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) sal_Int32 nNum, /// attribute value sal_Int32 nDefault); /// default value /// export a string attribute void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) const ::rtl::OUString& sValue, /// attribute value sal_Bool bOmitEmpty = sal_False, /// omit attribute, if value is empty sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string attribute taht gets a QName value void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) sal_uInt16 nValuePrefix, const ::rtl::OUString& sValue, /// attribute value sal_Bool bOmitEmpty = sal_False, /// omit attribute, if value is empty sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string attribute, omit if default void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) const ::rtl::OUString& sValue, /// attribute value const ::rtl::OUString& sDefault, /// default value; omit if equal sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string attribute, omit if default void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) sal_uInt16 nValuePrefix, const ::rtl::OUString& sValue, /// attribute value const ::rtl::OUString& sDefault, /// default value; omit if equal sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string attribute void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) enum ::xmloff::token::XMLTokenEnum eValue, /// attribute token sal_Bool bOmitEmpty = sal_False, /// omit attribute, if value is empty sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string attribute, omit if default void ProcessString( enum ::xmloff::token::XMLTokenEnum eXmlName, /// attribute token (namespace text) enum ::xmloff::token::XMLTokenEnum eValue, /// attribute value token enum ::xmloff::token::XMLTokenEnum eDefault, /// default value token sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a string as a sequence of paragraphs void ProcessParagraphSequence( /// string containing the paragraphs const ::rtl::OUString& sParagraphSequence); /// export a numbering format (numeric, roman, alphabetic, etc.) void ProcessNumberingType( sal_Int16 nNumberingType); /// numbering type key /// export display attribute (value, formula, none) void ProcessDisplay(sal_Bool bIsVisible, /// is visible? sal_Bool bIsCommand, /// is show command/show name? sal_Bool bDefault = sal_True); /// omit, if default /// export all data-style related attributes void ProcessValueAndType( sal_Bool bIsString, /// do we process a string or a number? sal_Int32 nFormatKey, /// format key for NumberFormatter; possibly -1 const ::rtl::OUString& sContent, /// string content; possibly invalid const ::rtl::OUString& sDefault, /// default string double fValue, /// float content; possibly invalid sal_Bool bExportValue, /// export value attribute? sal_Bool bExportValueType, /// export value-type attribute? sal_Bool bExportStyle, /// export style-sttribute? sal_Bool bForceSystemLanguage, /// no style language export sal_Bool bTimeStyle = sal_False); /// exporting a time style? /// export times, dates and durations according to ISO 8601 void ProcessDateTime( enum ::xmloff::token::XMLTokenEnum eXMLName, /// attribute token double dValue, /// date/time value sal_Bool bIsDate, /// export as date (rather than date/time)? sal_Bool bIsDuration = sal_False, /// export as duration sal_Bool bOmitDurationIfZero = sal_True, /// omit zero-length durat. sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export a date, time, or duration void ProcessDateTime( enum ::xmloff::token::XMLTokenEnum eXMLName, /// attribute token sal_Int32 nMinutes, /// date/time value in minutes sal_Bool bIsDate, /// export as date? sal_Bool bIsDuration, /// export as duration? sal_Bool bOmitDurationIfZero, /// omit zero-length durations sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export times, dates and durations according to ISO 8601 void ProcessDateTime( enum ::xmloff::token::XMLTokenEnum eXMLName, /// attribute token const ::com::sun::star::util::DateTime& rTime, /// date/time value sal_Bool bIsDate, /// export as date (rather than date/time)? sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export date according to ISO 8601 void ProcessDate( enum ::xmloff::token::XMLTokenEnum eXMLName, /// attribute token const ::com::sun::star::util::Date& rTime, /// date value sal_uInt16 nPrefix = XML_NAMESPACE_TEXT); /// attribute name prefix /// export all attributes for bibliography data fields void ProcessBibliographyData( const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & rPropertySet); /// export CommandTypeAttribute void ProcessCommandType( sal_Int32 nCommandType); /// com::sun::star::sdb::CommandType void ProcessStringSequence( const ::com::sun::star::uno::Sequence& rSequence, const rtl::OUString sSelected ); void ProcessStringSequence( const ::com::sun::star::uno::Sequence& rSequence, sal_Int32 nSelected ); /// export attributes that describe a data source void ExportDataBaseElement( enum ::xmloff::token::XMLTokenEnum eElement, const ::rtl::OUString& sContent, const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & rPropertySet, const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySetInfo > & rPropertySetInfo ); /// for XDependentTextFields, get PropertySet of FieldMaster ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > GetMasterPropertySet(const ::com::sun::star::uno::Reference < ::com::sun::star::text::XTextField > & rTextField); /// get PropertySet of (any) DependentTextField for this FieldMaster sal_Bool GetDependentFieldPropertySet( const ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & xmaster, ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet> & xField); /// get field ID from XTextField (and it's Property-Set) enum FieldIdEnum GetFieldID(const ::com::sun::star::uno::Reference < ::com::sun::star::text::XTextField > & rTextField, const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & xPropSet); /// get field ID from XTextField service name (and it's PropertySet) enum FieldIdEnum MapFieldName(const ::rtl::OUString& sFieldName, const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet> & xPropSet); /// determine, whether field has string or numeric content sal_Bool IsStringField(sal_uInt16 nFieldType, /// field ID const ::com::sun::star::uno::Reference < ::com::sun::star::beans::XPropertySet > & xPropSet); /// explode a field master name into field type and field name sal_Bool ExplodeFieldMasterName( const ::rtl::OUString& sMasterName, /// name as returned by SO API ::rtl::OUString& sFieldType, /// out: field type ::rtl::OUString& sVarName); /// out: variable name /// make reference name for a foot- or endnote static ::rtl::OUString MakeFootnoteRefName(sal_Int16 nSeqNo); /// make reference name for a sequence field static ::rtl::OUString MakeSequenceRefName(sal_Int16 nSeqNo, const ::rtl::OUString& rSeqName); private: // constants // service names const ::rtl::OUString sServicePrefix; const ::rtl::OUString sFieldMasterPrefix; const ::rtl::OUString sPresentationServicePrefix; // property names const ::rtl::OUString sPropertyAdjust; const ::rtl::OUString sPropertyAuthor; const ::rtl::OUString sPropertyChapterFormat; const ::rtl::OUString sPropertyChapterNumberingLevel; const ::rtl::OUString sPropertyCharStyleNames; const ::rtl::OUString sPropertyCondition; const ::rtl::OUString sPropertyContent; const ::rtl::OUString sPropertyDataBaseName; const ::rtl::OUString sPropertyDataBaseURL; const ::rtl::OUString sPropertyDataColumnName; const ::rtl::OUString sPropertyDataCommandType; const ::rtl::OUString sPropertyDataTableName; const ::rtl::OUString sPropertyDate; const ::rtl::OUString sPropertyDateTime; const ::rtl::OUString sPropertyDateTimeValue; const ::rtl::OUString sPropertyDDECommandElement; const ::rtl::OUString sPropertyDDECommandFile; const ::rtl::OUString sPropertyDDECommandType; const ::rtl::OUString sPropertyDependentTextFields; const ::rtl::OUString sPropertyFalseContent; const ::rtl::OUString sPropertyFields; const ::rtl::OUString sPropertyFieldSubType; const ::rtl::OUString sPropertyFileFormat; const ::rtl::OUString sPropertyFullName; const ::rtl::OUString sPropertyHint; const ::rtl::OUString sPropertyInstanceName; const ::rtl::OUString sPropertyIsAutomaticUpdate; const ::rtl::OUString sPropertyIsConditionTrue; const ::rtl::OUString sPropertyIsDataBaseFormat; const ::rtl::OUString sPropertyIsDate; const ::rtl::OUString sPropertyIsExpression; const ::rtl::OUString sPropertyIsFixed; const ::rtl::OUString sPropertyIsFixedLanguage; const ::rtl::OUString sPropertyIsHidden; const ::rtl::OUString sPropertyIsInput; const ::rtl::OUString sPropertyIsShowFormula; const ::rtl::OUString sPropertyIsVisible; const ::rtl::OUString sPropertyItems; const ::rtl::OUString sPropertyLevel; const ::rtl::OUString sPropertyMacro; const ::rtl::OUString sPropertyMeasureKind; const ::rtl::OUString sPropertyName; const ::rtl::OUString sPropertyNumberFormat; const ::rtl::OUString sPropertyNumberingSeparator; const ::rtl::OUString sPropertyNumberingType; const ::rtl::OUString sPropertyOffset; const ::rtl::OUString sPropertyOn; const ::rtl::OUString sPropertyPlaceholder; const ::rtl::OUString sPropertyPlaceholderType; const ::rtl::OUString sPropertyReferenceFieldPart; const ::rtl::OUString sPropertyReferenceFieldSource; const ::rtl::OUString sPropertyReferenceFieldType; const ::rtl::OUString sPropertyRevision; const ::rtl::OUString sPropertyScriptType; const ::rtl::OUString sPropertySelectedItem; const ::rtl::OUString sPropertySequenceNumber; const ::rtl::OUString sPropertySequenceValue; const ::rtl::OUString sPropertySetNumber; const ::rtl::OUString sPropertySourceName; const ::rtl::OUString sPropertySubType; const ::rtl::OUString sPropertyTargetFrame; const ::rtl::OUString sPropertyTrueContent; const ::rtl::OUString sPropertyURL; const ::rtl::OUString sPropertyURLContent; const ::rtl::OUString sPropertyUserText; const ::rtl::OUString sPropertyValue; const ::rtl::OUString sPropertyVariableName; const ::rtl::OUString sPropertyVariableSubType; const ::rtl::OUString sEmpty; XMLPropertyState* pCombinedCharactersPropertyState; }; #endif