1/*************************************************************************
2 *
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
6 *
7 * OpenOffice.org - a multi-platform office productivity suite
8 *
9 * This file is part of OpenOffice.org.
10 *
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
14 *
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
20 *
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org.  If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
25 *
26 ************************************************************************/
27#ifndef __com_sun_star_text_RedlinePortion_idl__
28#define __com_sun_star_text_RedlinePortion_idl__
29
30#ifndef __com_sun_star_text_TextPortion_idl__
31#include <com/sun/star/text/TextPortion.idl>
32#endif
33#ifndef __com_sun_star_beans_PropertyValues_idl__
34#include <com/sun/star/beans/PropertyValues.idl>
35#endif
36#ifndef __com_sun_star_util_DateTime_idl__
37#include <com/sun/star/util/DateTime.idl>
38#endif
39
40//=============================================================================
41
42module com { module sun { module star { module text {
43
44//=============================================================================
45/** A RedlinePortion is a TextPortion that marks a change that has been recorded by
46the change tracking.
47
48*/
49published service RedlinePortion
50{
51    service com::sun::star::text::TextPortion;
52    /** contains the name of the author of the change.*/
53    [readonly, property] string RedlineAuthor;
54    /** contains the date and time of the change.*/
55    [readonly, property] com::sun::star::util::DateTime RedlineDateTime;
56    /** contains a comment for the change.*/
57    [readonly, property] string RedlineComment;
58    /** contains the type of the change
59    <p> Valid type names are:</p>
60	<UL>
61        <LI><P>Insert - marks an insertion</P>
62        <LI><P>Delete - marks an deletion</P>
63        <LI><P>Format - marks an attribute change</P>
64        <LI><P>TextTable - marks a text table</P>
65        <LI><P>Style - marks an applied style</P>
66    </UL>
67     */
68    [readonly, property] string RedlineType;
69    /** contains the data of a second level redline data
70        <p> The elements of the sequence are:</p>
71        <UL>
72            <LI><P>string RedlineAuthor;                              </P>
73            <LI><P>com::sun::star::util::DateTime RedlineDateTime;    </P>
74            <LI><P>string RedlineComment;                             </P>
75            <LI><P>string RedlineType;                                </P>
76        </UL>
77     */
78    [readonly, property] com::sun::star::beans::PropertyValues RedlineSuccessorData;
79    /** contains a unique identifier for the redline.
80     This is necessary for file export filters to able to recognize redline portions
81        that point to the same redline.*/
82    [readonly, property] string RedlineIdentifier;
83    /** determines whether the portion is member of a header or footer text.*/
84    [readonly, property] boolean IsInHeaderFooter;
85    /** provides access to the text of the redline. This interface is only provided
86     if the change is not visible. The visibility depends on the redline display options that
87     are set at the documents property set (RedlineDisplayType).*/
88    [readonly, property] com::sun::star::text::XText RedlineText;
89    /** determines whether the last paragraph of a redline text has to be merged with a
90     possible following text content (i.e. a text table)*/
91    [readonly, property] boolean MergeLastPara;
92};
93
94//=============================================================================
95
96}; }; }; };
97#endif
98
99