/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include #include #include #include #include #include #include #include #include #include #include using namespace css; using namespace css::uno; namespace apitest { constexpr OUString colLevel1 = u"OutlineSheet.A1:Z1"_ustr; constexpr OUString colLevel2 = u"OutlineSheet.C1:W1"_ustr; constexpr OUString colLevel3 = u"OutlineSheet.E1:U1"_ustr; constexpr OUStringLiteral colLevel4 = u"OutlineSheet.G1:S1"; constexpr OUString rowLevel1 = u"OutlineSheet.A1:A30"_ustr; constexpr OUString rowLevel2 = u"OutlineSheet.A3:A27"_ustr; static OUString getVisibleAddress( uno::Reference const& xSheet, const OUString& aLevelRangeString) { uno::Reference aSheetRangeAccess(xSheet, UNO_QUERY_THROW); uno::Reference aLevelRange = aSheetRangeAccess->getCellRangeByName(aLevelRangeString); uno::Reference xCellRangesQuery(aLevelRange,UNO_QUERY_THROW); uno::Reference xRanges = xCellRangesQuery->queryVisibleCells(); OUString aResult = xRanges->getRangeAddressesAsString(); return aResult; } static table::CellRangeAddress getAddressFromRangeString( uno::Reference const& xSheet, const OUString& aStringAddress) { uno::Reference< table::XCellRange > aSheetRangeAccess(xSheet, UNO_QUERY_THROW); uno::Reference aRange = aSheetRangeAccess->getCellRangeByName(aStringAddress); uno::Reference xCellRangeAddressable(aRange, UNO_QUERY_THROW); table::CellRangeAddress aLevelRangeAddress = xCellRangeAddressable->getRangeAddress(); return aLevelRangeAddress; } void XSheetOutline::testHideDetail() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); // Column level 2 table::CellRangeAddress aLevelRangeAddress = getAddressFromRangeString(aSheet, colLevel2); aSheetOutline->hideDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("Column level 2 not hidden", getVisibleAddress(aSheet, colLevel2), OUString()); // Row Level 2 aLevelRangeAddress = getAddressFromRangeString(aSheet, rowLevel2); aSheetOutline->hideDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("Row level 2 not hidden", getVisibleAddress(aSheet, rowLevel2), OUString()); } void XSheetOutline::testShowDetail() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); aSheetOutline->showDetail(getAddressFromRangeString(aSheet, colLevel1)); aSheetOutline->showDetail(getAddressFromRangeString(aSheet, rowLevel1)); // Row Level 2 table::CellRangeAddress aLevelRangeAddress = getAddressFromRangeString(aSheet, rowLevel2); aSheetOutline->showDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("Row level 2 still hidden", rowLevel2, getVisibleAddress(aSheet, rowLevel2)); // Column Level 2 aLevelRangeAddress = getAddressFromRangeString(aSheet, colLevel2); aSheetOutline->showDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("Column level 2 still hidden", colLevel2, getVisibleAddress(aSheet, colLevel2)); } void XSheetOutline::testShowLevel() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); // test columns table::CellRangeAddress aLevel1 = getAddressFromRangeString(aSheet, colLevel1); table::CellRangeAddress aLevel2 = getAddressFromRangeString(aSheet, colLevel2); table::CellRangeAddress aLevel3 = getAddressFromRangeString(aSheet, colLevel3); table::CellRangeAddress aLevel4 = getAddressFromRangeString(aSheet, colLevel4); aSheetOutline->showDetail(getAddressFromRangeString(aSheet, colLevel1)); aSheetOutline->showDetail(getAddressFromRangeString(aSheet, colLevel2)); aSheetOutline->showDetail(getAddressFromRangeString(aSheet, rowLevel1)); aSheetOutline->hideDetail(aLevel1); aSheetOutline->hideDetail(aLevel2); aSheetOutline->hideDetail(aLevel3); aSheetOutline->hideDetail(aLevel4); aSheetOutline->showLevel(2, table::TableOrientation_COLUMNS); std::cout << " verify showLevel col apres" << getVisibleAddress(aSheet, u"OutlineSheet.A1:Z30"_ustr) << std::endl; // verify that level 2 and level 1 are shown --> column 0..3 & column 22..26 // level 3 & 4 are hidden --> column 4..19 CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Column", u"OutlineSheet.A1:D1"_ustr, getVisibleAddress(aSheet, u"OutlineSheet.A1:D1"_ustr)); CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Column", u"OutlineSheet.V1:Z1"_ustr, getVisibleAddress(aSheet, u"OutlineSheet.V1:Z1"_ustr)); CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Column", OUString(), getVisibleAddress(aSheet, colLevel3)); /* FIXME !! // test Rows aLevel1 = getAddressFromRangeString(rowLevel1); aLevel2 = getAddressFromRangeString(rowLevel2); aLevel3 = getAddressFromRangeString(rowLevel3); aLevel4 = getAddressFromRangeString(rowLevel4); aSheetOutline->showDetail(getAddressFromRangeString(colLevel1)); aSheetOutline->showDetail(getAddressFromRangeString(rowLevel1)); aSheetOutline->showDetail(getAddressFromRangeString(rowLevel2)); std::cout << " verify showLevel row before" << OUStringToOString(getVisibleAddress("OutlineSheet.A1:Z30"), RTL_TEXTENCODING_UTF8).getStr() << std::endl; aSheetOutline->hideDetail(aLevel1); aSheetOutline->hideDetail(aLevel2); aSheetOutline->hideDetail(aLevel3); aSheetOutline->hideDetail(aLevel4); std::cout << " verify showLevel row just before" << OUStringToOString(getVisibleAddress("OutlineSheet.A1:Z30"), RTL_TEXTENCODING_UTF8).getStr() << std::endl; aSheetOutline->showLevel(2, table::TableOrientation_ROWS); std::cout << " verify showLevel row after" << OUStringToOString(getVisibleAddress("OutlineSheet.A1:Z30"), RTL_TEXTENCODING_UTF8).getStr() << std::endl; // verify rows visible 0..3 & 24..29 // verify rows hidden 4..23 CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Row", OUString("OutlineSheet.A1:A4"), getVisibleAddress("OutlineSheet.A1:A4")); CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Row", OUString("OutlineSheet.A25:A30"), getVisibleAddress("OutlineSheet.A25:A30")); CPPUNIT_ASSERT_EQUAL_MESSAGE("testShowLevel Row", OUString(), getVisibleAddress(rowLevel3)); */ } void XSheetOutline::testGroup() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); // Column level 2 OUString aNewString = u"OutlineSheet.AB1:AG1"_ustr; table::CellRangeAddress aLevelRangeAddress = getAddressFromRangeString(aSheet, aNewString); aSheetOutline->group(aLevelRangeAddress, table::TableOrientation_COLUMNS); aSheetOutline->hideDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("testGroup Column still visible", getVisibleAddress(aSheet, aNewString), OUString()); // Row Level 2 aNewString = "OutlineSheet.A50:A60"; aLevelRangeAddress = getAddressFromRangeString(aSheet, aNewString); aSheetOutline->group(aLevelRangeAddress, table::TableOrientation_ROWS); aSheetOutline->hideDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("testGroup Row still visible", getVisibleAddress(aSheet, aNewString), OUString()); } void XSheetOutline::testUngroup() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); // New Column level OUString aNewString = u"OutlineSheet.BB1:BG1"_ustr; table::CellRangeAddress aLevelRangeAddress = getAddressFromRangeString(aSheet, aNewString); aSheetOutline->group(aLevelRangeAddress, table::TableOrientation_COLUMNS); aSheetOutline->hideDetail(aLevelRangeAddress); aSheetOutline->ungroup(aLevelRangeAddress, table::TableOrientation_COLUMNS); aSheetOutline->showDetail(aLevelRangeAddress); // should remain hidden ? CPPUNIT_ASSERT_EQUAL_MESSAGE("testUnGroup Column becomes visible after ungroup", getVisibleAddress(aSheet, aNewString), OUString()); // New Row level aNewString = "OutlineSheet.A70:A80"; aLevelRangeAddress = getAddressFromRangeString(aSheet, aNewString); aSheetOutline->group(aLevelRangeAddress, table::TableOrientation_ROWS); aSheetOutline->hideDetail(aLevelRangeAddress); aSheetOutline->ungroup(aLevelRangeAddress, table::TableOrientation_ROWS); aSheetOutline->showDetail(aLevelRangeAddress); // should remain hidden ? CPPUNIT_ASSERT_EQUAL_MESSAGE("testUnGroup Row becomes visible after ungroup", getVisibleAddress(aSheet, aNewString), OUString()); } void XSheetOutline::testClearOutline() { uno::Reference< sheet::XSpreadsheet > aSheet(init(), UNO_QUERY_THROW); uno::Reference< sheet::XSheetOutline > aSheetOutline(aSheet, UNO_QUERY_THROW); aSheetOutline->clearOutline(); table::CellRangeAddress aLevelRangeAddress = getAddressFromRangeString(aSheet, colLevel1); aSheetOutline->hideDetail(aLevelRangeAddress); aLevelRangeAddress = getAddressFromRangeString(aSheet, rowLevel1); aSheetOutline->hideDetail(aLevelRangeAddress); CPPUNIT_ASSERT_EQUAL_MESSAGE("testClearOutline Columns are hidden after clear", colLevel1, getVisibleAddress(aSheet, colLevel1)); CPPUNIT_ASSERT_EQUAL_MESSAGE("testClearOutline Rows are hidden after clear", rowLevel1, getVisibleAddress(aSheet, rowLevel1)); } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */