/** * *************************************************************************** * Copyright (c) 2010 Qcadoo Limited * Project: Qcadoo MES * Version: 1.4 * * This file is part of Qcadoo. * * Qcadoo is free software; you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published * by the Free Software Foundation; either version 3 of the License, * or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * *************************************************************************** */ package com.qcadoo.mes.basic; import java.util.HashMap; import java.util.List; import java.util.Map; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.google.common.base.Preconditions; import com.qcadoo.mes.basic.constants.BasicConstants; import com.qcadoo.mes.basic.constants.CharType; import com.qcadoo.mes.basic.constants.ReportColumnWidthFields; import com.qcadoo.model.api.DataDefinition; import com.qcadoo.model.api.DataDefinitionService; import com.qcadoo.model.api.Entity; /** * Service for accessing parameters * * @since 1.1.5 */ @Service public class ParameterService { private static final Integer SMALL_CHAR_IN_PIXEL = 9; private static final Integer LARGE_CHAR_IN_PIXEL = 11; @Autowired private DataDefinitionService dataDefinitionService; /** * Returns basic parameter entity id for current user * * @return parameter entity id * */ public Long getParameterId() { return getParameter().getId(); } /** * Returns basic parameter entity for current user. If parameter does not exist the new parameter entity will be created, * saved and returned. * * @return parameter entity * */ @Transactional public Entity getParameter() { Entity parameter = null; DataDefinition parameterDD = dataDefinitionService.get(BasicConstants.PLUGIN_IDENTIFIER, BasicConstants.MODEL_PARAMETER); if (parameterDD != null) { parameter = parameterDD.find("SELECT p FROM #basic_parameter p").setMaxResults(1).setCacheable(true).uniqueResult(); if (parameter == null) { parameter = createParameter(parameterDD); } } return parameter; } private Entity createParameter(final DataDefinition dataDefinition) { Entity parameter = dataDefinition.create(); parameter = dataDefinition.save(parameter); Preconditions.checkState(parameter.isValid(), "Parameter entity has validation errors! " + parameter); return parameter; } public Map<String, Integer> getReportColumnWidths() { int converterValue = 0; Map<String, Integer> reportColumnWidthsMap = new HashMap<String, Integer>(); DataDefinition reportColumnWidthDD = dataDefinitionService.get(BasicConstants.PLUGIN_IDENTIFIER, BasicConstants.MODEL_REPORT_COLUMN_WIDTH); List<Entity> reportColumnWidths = reportColumnWidthDD.find().list().getEntities(); for (Entity reportColumnWidth : reportColumnWidths) { if (reportColumnWidth.getIntegerField(ReportColumnWidthFields.WIDTH) != null) { if (CharType.SMALL_CHARS.getStringValue().equals( reportColumnWidth.getStringField(ReportColumnWidthFields.CHAR_TYPE))) { converterValue = SMALL_CHAR_IN_PIXEL; } else { converterValue = LARGE_CHAR_IN_PIXEL; } reportColumnWidthsMap.put(reportColumnWidth.getStringField(ReportColumnWidthFields.IDENTIFIER), reportColumnWidth.getIntegerField(ReportColumnWidthFields.WIDTH) * converterValue); } } return reportColumnWidthsMap; } }