LibreOffice Module lotuswordpro (master) 1
xftimestyle.cxx
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*************************************************************************
3 *
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
6 *
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
9 *
10 * Sun Microsystems Inc., October, 2000
11 *
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
16 *
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
20 *
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
25 *
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
29 * MA 02111-1307 USA
30 *
31 *
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
38 *
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
45 *
46 * The Initial Developer of the Original Code is: IBM Corporation
47 *
48 * Copyright: 2008 by IBM Corporation
49 *
50 * All Rights Reserved.
51 *
52 * Contributor(s): _______________________________________
53 *
54 *
55 ************************************************************************/
56/*************************************************************************
57 * @file
58 * Time style. The Time format for time field.
59 ************************************************************************/
60
63
65{
66 m_nDecimalPos = 0;
67}
68
70{
71 IXFAttrList *pAttrList = pStrm->GetAttrList();
72
73 switch(m_ePart)
74 {
75 case enumXFDateHour:
76 pAttrList->Clear();
77 if( m_bLongFmt )
78 pAttrList->AddAttribute( "number:style", "long" );
79 pStrm->StartElement( "number:hours" );
80 pStrm->EndElement( "number:hours" );
81 break;
83 pAttrList->Clear();
84 if( m_bLongFmt )
85 pAttrList->AddAttribute( "number:style", "long" );
86 if( m_nDecimalPos>0 )
87 pAttrList->AddAttribute( "number:decimal-places", OUString::number(m_nDecimalPos) );
88
89 pStrm->StartElement( "number:minutes" );
90 pStrm->EndElement( "number:minutes" );
91 break;
93 pAttrList->Clear();
94 if( m_bLongFmt )
95 pAttrList->AddAttribute( "number:style", "long" );
96 pStrm->StartElement( "number:seconds" );
97 pStrm->EndElement( "number:seconds" );
98 break;
99 case enumXFDateText:
100 pAttrList->Clear();
101 pStrm->StartElement( "number:text" );
102 pStrm->Characters( m_strText );
103 pStrm->EndElement( "number:text" );
104 break;
105 default:
106 break;
107 }
108}
109
111{
112 m_bAmPm = false;
113 m_bTruncate = true;
114}
115
117{
118}
119
121{
122 return enumXFStyleTime;
123}
124
126{
127 IXFAttrList *pAttrList = pStrm->GetAttrList();
128
129 pAttrList->Clear();
130 pAttrList->AddAttribute( "style:name", GetStyleName() );
131 if( !GetParentStyleName().isEmpty() )
132 pAttrList->AddAttribute("style:parent-style-name",GetParentStyleName());
133 pAttrList->AddAttribute( "style:family", "data-style" );
134 if (!m_bTruncate)
135 pAttrList->AddAttribute( "number:truncate-on-overflow", "false" );
136 pStrm->StartElement( "number:time-style" );
137
138 for (auto & part : m_aParts)
139 {
140 part.ToXml(pStrm);
141 }
142 if( m_bAmPm )
143 {
144 pAttrList->Clear();
145 pStrm->StartElement( "number:am-pm" );
146 pStrm->EndElement( "number:am-pm" );
147 }
148 pStrm->EndElement( "number:time-style" );
149}
150/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Attribute list interface for sax writer.
Definition: ixfattrlist.hxx:72
virtual void Clear()=0
@descr: Clear all the attributes in the attribute list.
virtual void AddAttribute(const OUString &name, const OUString &value)=0
@descr: Add an attribute to the attribute list.
Stream wrapper for sax writer.
Definition: ixfstream.hxx:72
virtual void Characters(const OUString &oustr)=0
@descr output text node.
virtual IXFAttrList * GetAttrList()=0
@descr return the Attribute list interface.
virtual void StartElement(const OUString &oustr)=0
@descr Wrap XDocumentHandler::startElement()
virtual void EndElement(const OUString &oustr)=0
@descr Wrap XDocumentHandler::endElement()
enumXFDatePart m_ePart
Definition: xftimestyle.hxx:81
OUString m_strText
Definition: xftimestyle.hxx:83
virtual OUString GetStyleName() override
@descr get style name.
Definition: xfstyle.cxx:70
virtual OUString GetParentStyleName() override
@descr set parent style name.
Definition: xfstyle.cxx:80
virtual void ToXml(IXFStream *pStrm) override
Definition: xftimestyle.cxx:69
sal_Int32 m_nDecimalPos
Definition: xftimestyle.hxx:96
std::vector< XFTimePart > m_aParts
virtual ~XFTimeStyle() override
virtual enumXFStyle GetStyleFamily() override
@descr get style family.
virtual void ToXml(IXFStream *pStrm) override
enumXFStyle
Definition: xfdefs.hxx:80
@ enumXFStyleTime
Definition: xfdefs.hxx:90
@ enumXFDateSecond
Definition: xfdefs.hxx:250
@ enumXFDateMinute
Definition: xfdefs.hxx:249
@ enumXFDateText
Definition: xfdefs.hxx:252
@ enumXFDateHour
Definition: xfdefs.hxx:248