1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ 2 /* 3 * This file is part of the LibreOffice project. 4 * 5 * This Source Code Form is subject to the terms of the Mozilla Public 6 * License, v. 2.0. If a copy of the MPL was not distributed with this 7 * file, You can obtain one at http://mozilla.org/MPL/2.0/. 8 * 9 * This file incorporates work covered by the following license notice: 10 * 11 * Licensed to the Apache Software Foundation (ASF) under one or more 12 * contributor license agreements. See the NOTICE file distributed 13 * with this work for additional information regarding copyright 14 * ownership. The ASF licenses this file to you under the Apache 15 * License, Version 2.0 (the "License"); you may not use this file 16 * except in compliance with the License. You may obtain a copy of 17 * the License at http://www.apache.org/licenses/LICENSE-2.0 . 18 */ 19 20 #include <drawinglayer/primitive2d/texthierarchyprimitive2d.hxx> 21 #include <drawinglayer/primitive2d/drawinglayer_primitivetypes2d.hxx> 22 23 24 using namespace com::sun::star; 25 26 27 namespace drawinglayer::primitive2d 28 { TextHierarchyLinePrimitive2D(const Primitive2DContainer & rChildren)29 TextHierarchyLinePrimitive2D::TextHierarchyLinePrimitive2D(const Primitive2DContainer& rChildren) 30 : GroupPrimitive2D(rChildren) 31 { 32 } 33 34 // provide unique ID ImplPrimitive2DIDBlock(TextHierarchyLinePrimitive2D,PRIMITIVE2D_ID_TEXTHIERARCHYLINEPRIMITIVE2D)35 ImplPrimitive2DIDBlock(TextHierarchyLinePrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYLINEPRIMITIVE2D) 36 37 38 TextHierarchyParagraphPrimitive2D::TextHierarchyParagraphPrimitive2D( 39 const Primitive2DContainer& rChildren, 40 sal_Int16 nOutlineLevel) 41 : GroupPrimitive2D(rChildren), 42 mnOutlineLevel(nOutlineLevel) 43 { 44 } 45 operator ==(const BasePrimitive2D & rPrimitive) const46 bool TextHierarchyParagraphPrimitive2D::operator==(const BasePrimitive2D& rPrimitive) const 47 { 48 if(GroupPrimitive2D::operator==(rPrimitive)) 49 { 50 const TextHierarchyParagraphPrimitive2D& rCompare = static_cast<const TextHierarchyParagraphPrimitive2D&>(rPrimitive); 51 52 return (getOutlineLevel() == rCompare.getOutlineLevel()); 53 } 54 55 return false; 56 } 57 58 // provide unique ID ImplPrimitive2DIDBlock(TextHierarchyParagraphPrimitive2D,PRIMITIVE2D_ID_TEXTHIERARCHYPARAGRAPHPRIMITIVE2D)59 ImplPrimitive2DIDBlock(TextHierarchyParagraphPrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYPARAGRAPHPRIMITIVE2D) 60 61 62 63 TextHierarchyBulletPrimitive2D::TextHierarchyBulletPrimitive2D(const Primitive2DContainer& rChildren) 64 : GroupPrimitive2D(rChildren) 65 { 66 } 67 68 // provide unique ID ImplPrimitive2DIDBlock(TextHierarchyBulletPrimitive2D,PRIMITIVE2D_ID_TEXTHIERARCHYBULLETPRIMITIVE2D)69 ImplPrimitive2DIDBlock(TextHierarchyBulletPrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYBULLETPRIMITIVE2D) 70 71 72 TextHierarchyBlockPrimitive2D::TextHierarchyBlockPrimitive2D(const Primitive2DContainer& rChildren) 73 : GroupPrimitive2D(rChildren) 74 { 75 } 76 77 // provide unique ID ImplPrimitive2DIDBlock(TextHierarchyBlockPrimitive2D,PRIMITIVE2D_ID_TEXTHIERARCHYBLOCKPRIMITIVE2D)78 ImplPrimitive2DIDBlock(TextHierarchyBlockPrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYBLOCKPRIMITIVE2D) 79 80 81 TextHierarchyFieldPrimitive2D::TextHierarchyFieldPrimitive2D( 82 const Primitive2DContainer& rChildren, 83 const FieldType& rFieldType, 84 const std::vector< std::pair< OUString, OUString>>* pNameValue) 85 : GroupPrimitive2D(rChildren), 86 meType(rFieldType), 87 meNameValue() 88 { 89 if (nullptr != pNameValue) 90 { 91 meNameValue = *pNameValue; 92 } 93 } 94 getValue(const OUString & rName) const95 OUString TextHierarchyFieldPrimitive2D::getValue(const OUString& rName) const 96 { 97 for (const std::pair< OUString, OUString >& candidate : meNameValue) 98 { 99 if (candidate.first.equals(rName)) 100 { 101 return candidate.second; 102 } 103 } 104 105 return OUString(); 106 } 107 operator ==(const BasePrimitive2D & rPrimitive) const108 bool TextHierarchyFieldPrimitive2D::operator==(const BasePrimitive2D& rPrimitive) const 109 { 110 if(GroupPrimitive2D::operator==(rPrimitive)) 111 { 112 const TextHierarchyFieldPrimitive2D& rCompare = static_cast<const TextHierarchyFieldPrimitive2D&>(rPrimitive); 113 114 return (getType() == rCompare.getType() 115 && meNameValue == rCompare.meNameValue); 116 } 117 118 return false; 119 } 120 121 // provide unique ID ImplPrimitive2DIDBlock(TextHierarchyFieldPrimitive2D,PRIMITIVE2D_ID_TEXTHIERARCHYFIELDPRIMITIVE2D)122 ImplPrimitive2DIDBlock(TextHierarchyFieldPrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYFIELDPRIMITIVE2D) 123 TextHierarchyEditPrimitive2D::TextHierarchyEditPrimitive2D(const Primitive2DContainer& rChildren) 124 : GroupPrimitive2D(rChildren) 125 { 126 } 127 128 // provide unique ID 129 ImplPrimitive2DIDBlock(TextHierarchyEditPrimitive2D, PRIMITIVE2D_ID_TEXTHIERARCHYEDITPRIMITIVE2D) 130 131 } // end of namespace 132 133 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ 134