[Libreoffice-commits] core.git: sw/qa sw/source

Miklos Vajna (via logerrit) logerrit at kemper.freedesktop.org
Fri Jun 11 10:52:15 UTC 2021


 sw/qa/uibase/frmdlg/data/image.png |binary
 sw/qa/uibase/frmdlg/frmdlg.cxx     |   27 +++++++++++++++++++++++++++
 sw/source/uibase/frmdlg/frmmgr.cxx |   14 +++++++++++++-
 3 files changed, 40 insertions(+), 1 deletion(-)

New commits:
commit 7413cc96d239f5fd5a588f13784ccb82b6968bac
Author:     Miklos Vajna <vmiklos at collabora.com>
AuthorDate: Fri Jun 11 11:41:41 2021 +0200
Commit:     Miklos Vajna <vmiklos at collabora.com>
CommitDate: Fri Jun 11 12:51:32 2021 +0200

    sw image anchor type: consider a style-based custom value
    
    The anchor type is determined during insertion, it's stored as direct
    formatting after that.
    
    We used to have a user-profile default for the anchor type. This commit
    allows customizing the Graphics or OLE styles: if they specify a custom
    anchor type, then that is user instead of the user profile setting.
    
    This allows creating templates where the default depends on the used
    template and not on the user profile.
    
    The UI for this was added in commit
    5951da5175b9d7e5b3b47bd0d90989d2ef528c79 (sw image anchor type: add
    style UI for this, 2021-06-10).
    
    Change-Id: Id05342a5f38dc6267cdbe68b248dc50b87854ce2
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/117040
    Reviewed-by: Miklos Vajna <vmiklos at collabora.com>
    Tested-by: Jenkins

diff --git a/sw/qa/uibase/frmdlg/data/image.png b/sw/qa/uibase/frmdlg/data/image.png
new file mode 100644
index 000000000000..fdad35484e7c
Binary files /dev/null and b/sw/qa/uibase/frmdlg/data/image.png differ
diff --git a/sw/qa/uibase/frmdlg/frmdlg.cxx b/sw/qa/uibase/frmdlg/frmdlg.cxx
index 56b96803686e..ce9367ea815b 100644
--- a/sw/qa/uibase/frmdlg/frmdlg.cxx
+++ b/sw/qa/uibase/frmdlg/frmdlg.cxx
@@ -9,6 +9,8 @@
 
 #include <swmodeltestbase.hxx>
 
+#include <comphelper/propertyvalue.hxx>
+
 #include <com/sun/star/text/TextContentAnchorType.hpp>
 
 constexpr OUStringLiteral DATA_DIRECTORY = u"/sw/qa/uibase/frmdlg/data/";
@@ -32,6 +34,31 @@ CPPUNIT_TEST_FIXTURE(SwUibaseFrmdlgTest, testWrappedMathObject)
                          getProperty<text::TextContentAnchorType>(getShape(1), "AnchorType"));
 }
 
+CPPUNIT_TEST_FIXTURE(SwUibaseFrmdlgTest, testAnchorTypeFromStyle)
+{
+    // Given a document with aGraphics style with anchor type set to as-character:
+    createSwDoc();
+    uno::Reference<beans::XPropertySet> xGraphics(getStyles("FrameStyles")->getByName("Graphics"),
+                                                  uno::UNO_QUERY);
+    xGraphics->setPropertyValue("AnchorType",
+                                uno::makeAny(text::TextContentAnchorType_AS_CHARACTER));
+
+    // When inserting an image:
+    OUString aImageURL = m_directories.getURLFromSrc(DATA_DIRECTORY) + "image.png";
+    uno::Sequence<beans::PropertyValue> aArgs = {
+        comphelper::makePropertyValue("FileName", aImageURL),
+    };
+    dispatchCommand(mxComponent, ".uno:InsertGraphic", aArgs);
+
+    // Then make sure the image's anchor type is as-char:
+    auto eActual = getProperty<text::TextContentAnchorType>(getShape(1), "AnchorType");
+    // Without the accompanying fix in place, this test would have failed with:
+    // - Expected: 1 (AS_CHARACTER)
+    // - Actual  : 4 (AT_CHARACTER)
+    // i.e. the anchor type from the style was ignored.
+    CPPUNIT_ASSERT_EQUAL(text::TextContentAnchorType_AS_CHARACTER, eActual);
+}
+
 CPPUNIT_PLUGIN_IMPLEMENT();
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/uibase/frmdlg/frmmgr.cxx b/sw/source/uibase/frmdlg/frmmgr.cxx
index fa5991baac56..2146b05d44e9 100644
--- a/sw/source/uibase/frmdlg/frmmgr.cxx
+++ b/sw/source/uibase/frmdlg/frmmgr.cxx
@@ -92,7 +92,19 @@ SwFlyFrameAttrMgr::SwFlyFrameAttrMgr( bool bNew, SwWrtShell* pSh, Frmmgr_Type nT
             {
                 // Default anchor for new graphics and objects is at-char, except for Math objects.
                 SwViewOption aViewOpt(*pSh->GetViewOptions());
-                m_aSet.Put(SwFormatAnchor(aViewOpt.GetDefaultAnchorType()));//RndStdIds::FLY_AT_CHAR
+
+                RndStdIds eAnchorType = aViewOpt.GetDefaultAnchorType();
+
+                const SwFormatAnchor rStyleAnchor
+                    = m_pOwnSh->GetFormatFromPool(nId)->GetAttrSet().GetAnchor();
+                if (rStyleAnchor.GetAnchorId() != RndStdIds::FLY_AT_PARA)
+                {
+                    // The style has a custom anchor type, prefer that over the user profile
+                    // default.
+                    eAnchorType = rStyleAnchor.GetAnchorId();
+                }
+
+                m_aSet.Put(SwFormatAnchor(eAnchorType));
             }
         }
     }


More information about the Libreoffice-commits mailing list