/* -*- 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/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include "bibconfig.hxx" #include #include #include #include #include using namespace ::com::sun::star::uno; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::container; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::sdb; static const char cDataSourceHistory[] = "DataSourceHistory"; Sequence const & BibConfig::GetPropertyNames() { static Sequence aNames = { "CurrentDataSource/DataSourceName", "CurrentDataSource/Command", "CurrentDataSource/CommandType", "BeamerHeight", "ViewHeight", "QueryText", "QueryField", "ShowColumnAssignmentWarning" }; return aNames; } BibConfig::BibConfig() : ConfigItem("Office.DataAccess/Bibliography", ConfigItemMode::NONE) , nTblOrQuery(0) , nBeamerSize(0) , nViewSize(0) , bShowColumnAssignmentWarning(false) { //Names of the default columns aColumnDefaults[0] = "Identifier"; aColumnDefaults[1] = "BibliographyType"; aColumnDefaults[2] = "Author"; aColumnDefaults[3] = "Title"; aColumnDefaults[4] = "Year"; aColumnDefaults[5] = "ISBN"; aColumnDefaults[6] = "Booktitle"; aColumnDefaults[7] = "Chapter"; aColumnDefaults[8] = "Edition"; aColumnDefaults[9] = "Editor"; aColumnDefaults[10] = "Howpublished"; aColumnDefaults[11] = "Institution"; aColumnDefaults[12] = "Journal"; aColumnDefaults[13] = "Month"; aColumnDefaults[14] = "Note"; aColumnDefaults[15] = "Annote"; aColumnDefaults[16] = "Number"; aColumnDefaults[17] = "Organizations"; aColumnDefaults[18] = "Pages"; aColumnDefaults[19] = "Publisher"; aColumnDefaults[20] = "Address"; aColumnDefaults[21] = "School"; aColumnDefaults[22] = "Series"; aColumnDefaults[23] = "ReportType"; aColumnDefaults[24] = "Volume"; aColumnDefaults[25] = "URL"; aColumnDefaults[26] = "Custom1"; aColumnDefaults[27] = "Custom2"; aColumnDefaults[28] = "Custom3"; aColumnDefaults[29] = "Custom4"; aColumnDefaults[30] = "Custom5"; const Sequence< OUString > aPropertyNames = GetPropertyNames(); const Sequence aPropertyValues = GetProperties( aPropertyNames ); const Any* pValues = aPropertyValues.getConstArray(); if(aPropertyValues.getLength() == aPropertyNames.getLength()) { for(int nProp = 0; nProp < aPropertyNames.getLength(); nProp++) { if(pValues[nProp].hasValue()) { switch(nProp) { case 0: pValues[nProp] >>= sDataSource; break; case 1: pValues[nProp] >>= sTableOrQuery; break; case 2: pValues[nProp] >>= nTblOrQuery; break; case 3: pValues[nProp] >>= nBeamerSize; break; case 4: pValues[nProp] >>= nViewSize ; break; case 5: pValues[nProp] >>= sQueryText ; break; case 6: pValues[nProp] >>= sQueryField; break; case 7: bShowColumnAssignmentWarning = *o3tl::doAccess(pValues[nProp]); break; } } } } const Sequence< OUString > aNodeNames = GetNodeNames(cDataSourceHistory); for(OUString const & nodeName : aNodeNames) { Sequence aHistoryNames(3); OUString* pHistoryNames = aHistoryNames.getArray(); OUString sPrefix = OUStringLiteral(cDataSourceHistory) + "/" + nodeName + "/"; pHistoryNames[0] = sPrefix + "DataSourceName"; pHistoryNames[1] = sPrefix + "Command"; pHistoryNames[2] = sPrefix + "CommandType"; Sequence aHistoryValues = GetProperties( aHistoryNames ); const Any* pHistoryValues = aHistoryValues.getConstArray(); if(aHistoryValues.getLength() == aHistoryNames.getLength()) { Mapping* pMapping = new Mapping; pHistoryValues[0] >>= pMapping->sURL; pHistoryValues[1] >>= pMapping->sTableName; pHistoryValues[2] >>= pMapping->nCommandType; //field assignment is contained in another set sPrefix += "Fields"; const Sequence< OUString > aAssignmentNodeNames = GetNodeNames(sPrefix); Sequence aAssignmentPropertyNames(aAssignmentNodeNames.getLength() * 2); OUString* pAssignmentPropertyNames = aAssignmentPropertyNames.getArray(); sal_Int16 nFieldIdx = 0; for(OUString const & assignName : aAssignmentNodeNames) { OUString sSubPrefix = sPrefix + "/" + assignName; pAssignmentPropertyNames[nFieldIdx] = sSubPrefix; pAssignmentPropertyNames[nFieldIdx++] += "/ProgrammaticFieldName"; pAssignmentPropertyNames[nFieldIdx] = sSubPrefix; pAssignmentPropertyNames[nFieldIdx++] += "/AssignedFieldName"; } Sequence aAssignmentValues = GetProperties(aAssignmentPropertyNames); const Any* pAssignmentValues = aAssignmentValues.getConstArray(); OUString sTempLogical; OUString sTempReal; sal_Int16 nSetMapping = 0; nFieldIdx = 0; for(sal_Int32 nFieldVal = 0; nFieldVal < aAssignmentValues.getLength() / 2; nFieldVal++) { pAssignmentValues[nFieldIdx++] >>= sTempLogical; pAssignmentValues[nFieldIdx++] >>= sTempReal; if(!(sTempLogical.isEmpty() || sTempReal.isEmpty())) { pMapping->aColumnPairs[nSetMapping].sLogicalColumnName = sTempLogical; pMapping->aColumnPairs[nSetMapping++].sRealColumnName = sTempReal; } } mvMappings.push_back(std::unique_ptr(pMapping)); } } } BibConfig::~BibConfig() { assert(!IsModified()); // should have been committed } BibDBDescriptor BibConfig::GetBibliographyURL() { BibDBDescriptor aRet; aRet.sDataSource = sDataSource; aRet.sTableOrQuery = sTableOrQuery; aRet.nCommandType = nTblOrQuery; return aRet; }; void BibConfig::SetBibliographyURL(const BibDBDescriptor& rDesc) { sDataSource = rDesc.sDataSource; sTableOrQuery = rDesc.sTableOrQuery; nTblOrQuery = rDesc.nCommandType; SetModified(); }; void BibConfig::Notify( const css::uno::Sequence& ) { } void BibConfig::ImplCommit() { PutProperties( GetPropertyNames(), {css::uno::Any(sDataSource), css::uno::Any(sTableOrQuery), css::uno::Any(nTblOrQuery), css::uno::Any(nBeamerSize), css::uno::Any(nViewSize), css::uno::Any(sQueryText), css::uno::Any(sQueryField), css::uno::Any(bShowColumnAssignmentWarning)}); ClearNodeSet(cDataSourceHistory); Sequence< PropertyValue > aNodeValues(mvMappings.size() * 3); PropertyValue* pNodeValues = aNodeValues.getArray(); sal_Int32 nIndex = 0; for(sal_Int32 i = 0; i < static_cast(mvMappings.size()); i++) { const Mapping* pMapping = mvMappings[i].get(); OUString sPrefix = OUStringLiteral(cDataSourceHistory) + "/_" + OUString::number(i) + "/"; pNodeValues[nIndex].Name = sPrefix + "DataSourceName"; pNodeValues[nIndex++].Value <<= pMapping->sURL; pNodeValues[nIndex].Name = sPrefix + "Command"; pNodeValues[nIndex++].Value <<= pMapping->sTableName; pNodeValues[nIndex].Name = sPrefix + "CommandType"; pNodeValues[nIndex++].Value <<= pMapping->nCommandType; SetSetProperties(cDataSourceHistory, aNodeValues); sPrefix += "Fields"; sal_Int32 nFieldAssignment = 0; OUString sFieldName = "/ProgrammaticFieldName"; OUString sDatabaseFieldName = "/AssignedFieldName"; ClearNodeSet( sPrefix ); while(nFieldAssignment < COLUMN_COUNT && !pMapping->aColumnPairs[nFieldAssignment].sLogicalColumnName.isEmpty()) { OUString sSubPrefix = sPrefix + "/_" + OUString::number(nFieldAssignment); Sequence< PropertyValue > aAssignmentValues(2); PropertyValue* pAssignmentValues = aAssignmentValues.getArray(); pAssignmentValues[0].Name = sSubPrefix; pAssignmentValues[0].Name += sFieldName; pAssignmentValues[0].Value <<= pMapping->aColumnPairs[nFieldAssignment].sLogicalColumnName; pAssignmentValues[1].Name = sSubPrefix; pAssignmentValues[1].Name += sDatabaseFieldName; pAssignmentValues[1].Value <<= pMapping->aColumnPairs[nFieldAssignment].sRealColumnName; SetSetProperties( sPrefix, aAssignmentValues ); nFieldAssignment++; } } } const Mapping* BibConfig::GetMapping(const BibDBDescriptor& rDesc) const { for(std::unique_ptr const & i : mvMappings) { Mapping& rMapping = *i; bool bURLEqual = rDesc.sDataSource == rMapping.sURL; if(rDesc.sTableOrQuery == rMapping.sTableName && bURLEqual) return &rMapping; } return nullptr; } void BibConfig::SetMapping(const BibDBDescriptor& rDesc, const Mapping* pSetMapping) { for(size_t i = 0; i < mvMappings.size(); i++) { Mapping& rMapping = *mvMappings[i]; bool bURLEqual = rDesc.sDataSource == rMapping.sURL; if(rDesc.sTableOrQuery == rMapping.sTableName && bURLEqual) { mvMappings.erase(mvMappings.begin()+i); break; } } mvMappings.push_back(std::make_unique(*pSetMapping)); SetModified(); } DBChangeDialogConfig_Impl::DBChangeDialogConfig_Impl() { } DBChangeDialogConfig_Impl::~DBChangeDialogConfig_Impl() { } const Sequence& DBChangeDialogConfig_Impl::GetDataSourceNames() { if(!aSourceNames.hasElements()) { Reference< XComponentContext > xContext( ::comphelper::getProcessComponentContext() ); Reference xDBContext = DatabaseContext::create(xContext); aSourceNames = xDBContext->getElementNames(); } return aSourceNames; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */