/* -*- 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 namespace { OUString getTextForType(ScCondFormatEntryType eType) { switch(eType) { case CONDITION: return ScResId(STR_COND_CONDITION); case COLORSCALE: return ScResId(STR_COND_COLORSCALE); case DATABAR: return ScResId(STR_COND_DATABAR); case FORMULA: return ScResId(STR_COND_FORMULA); case ICONSET: return ScResId(STR_COND_ICONSET); case DATE: return ScResId(STR_COND_DATE); default: break; } return OUString(); } OUString getExpression(sal_Int32 nIndex) { switch(nIndex) { case 0: return "="; case 1: return "<"; case 2: return ">"; case 3: return "<="; case 4: return ">="; case 5: return "!="; case 6: return ScResId(STR_COND_BETWEEN); case 7: return ScResId(STR_COND_NOTBETWEEN); case 8: return ScResId(STR_COND_DUPLICATE); case 9: return ScResId(STR_COND_UNIQUE); case 11: return ScResId(STR_COND_TOP10); case 12: return ScResId(STR_COND_BOTTOM10); case 13: return ScResId(STR_COND_TOP_PERCENT); case 14: return ScResId(STR_COND_BOTTOM_PERCENT); case 15: return ScResId(STR_COND_ABOVE_AVERAGE); case 16: return ScResId(STR_COND_BELOW_AVERAGE); case 17: return ScResId(STR_COND_ABOVE_EQUAL_AVERAGE); case 18: return ScResId(STR_COND_BELOW_EQUAL_AVERAGE); case 19: return ScResId(STR_COND_ERROR); case 20: return ScResId(STR_COND_NOERROR); case 21: return ScResId(STR_COND_BEGINS_WITH); case 22: return ScResId(STR_COND_ENDS_WITH); case 23: return ScResId(STR_COND_CONTAINS); case 24: return ScResId(STR_COND_NOT_CONTAINS); case 10: assert(false); } return OUString(); } OUString getDateString(sal_Int32 nIndex) { const TranslateId aCondStrs[] = { STR_COND_TODAY, STR_COND_YESTERDAY, STR_COND_TOMORROW, STR_COND_LAST7DAYS, STR_COND_THISWEEK, STR_COND_LASTWEEK, STR_COND_NEXTWEEK, STR_COND_THISMONTH, STR_COND_LASTMONTH, STR_COND_NEXTMONTH, STR_COND_THISYEAR, STR_COND_LASTYEAR, STR_COND_NEXTYEAR }; if (nIndex >= 0 && o3tl::make_unsigned(nIndex) < SAL_N_ELEMENTS(aCondStrs)) return ScResId(aCondStrs[nIndex]); assert(false); return OUString(); } } OUString ScCondFormatHelper::GetExpression(const ScConditionalFormat& rFormat, const ScAddress& rPos) { OUStringBuffer aBuffer; if(!rFormat.IsEmpty()) { switch(rFormat.GetEntry(0)->GetType()) { case ScFormatEntry::Type::Condition: case ScFormatEntry::Type::ExtCondition: { const ScConditionEntry* pEntry = static_cast(rFormat.GetEntry(0)); ScConditionMode eMode = pEntry->GetOperation(); if(eMode == ScConditionMode::Direct) { aBuffer.append(getTextForType(FORMULA) + " " + pEntry->GetExpression(rPos, 0)); } else { aBuffer.append(getTextForType(CONDITION) + " " + getExpression(static_cast(eMode)) + " "); if(eMode == ScConditionMode::Between || eMode == ScConditionMode::NotBetween) { aBuffer.append(pEntry->GetExpression(rPos, 0) + " " + ScResId(STR_COND_AND) + " " + pEntry->GetExpression(rPos, 1)); } else if(eMode <= ScConditionMode::NotEqual || eMode >= ScConditionMode::BeginsWith) { aBuffer.append(pEntry->GetExpression(rPos, 0)); } } } break; case ScFormatEntry::Type::Databar: aBuffer.append(getTextForType(DATABAR)); break; case ScFormatEntry::Type::Colorscale: aBuffer.append(getTextForType(COLORSCALE)); break; case ScFormatEntry::Type::Iconset: aBuffer.append(getTextForType(ICONSET)); break; case ScFormatEntry::Type::Date: { sal_Int32 nDateEntry = static_cast(static_cast(rFormat.GetEntry(0))->GetDateType()); aBuffer.append(getTextForType(DATE) + " " + getDateString(nDateEntry)); } break; } } return aBuffer.makeStringAndClear(); } OUString ScCondFormatHelper::GetExpression( ScCondFormatEntryType eType, sal_Int32 nIndex, std::u16string_view aStr1, std::u16string_view aStr2 ) { OUStringBuffer aBuffer(getTextForType(eType) + " "); if(eType == CONDITION) { // workaround missing FORMULA option in the conditions case // FORMULA is handled later if(nIndex > 9) ++nIndex; aBuffer.append(getExpression(nIndex)); if(nIndex <= 7 || nIndex >= 19) { aBuffer.append(OUString::Concat(" ") + aStr1); if(nIndex == 6 || nIndex == 7) { aBuffer.append(" " + ScResId(STR_COND_AND) + " " + aStr2); } } } else if(eType == FORMULA) { aBuffer.append(OUString::Concat(" ") + aStr1); } else if(eType == DATE) { aBuffer.append(getDateString(nIndex)); } return aBuffer.makeStringAndClear(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */