/************************************************************************ ** ** @file vindividualmeasurements.cpp ** @author Roman Telezhinsky ** @date 8 3, 2014 ** ** @brief ** @copyright ** This source code is part of the Valentine project, a pattern making ** program, whose allow create and modeling patterns of clothing. ** Copyright (C) 2013 Valentina project ** All Rights Reserved. ** ** Valentina is free software: you can redistribute it and/or modify ** it under the terms of the GNU General Public License as published by ** the Free Software Foundation, either version 3 of the License, or ** (at your option) any later version. ** ** Valentina 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 General Public License for more details. ** ** You should have received a copy of the GNU General Public License ** along with Valentina. If not, see . ** *************************************************************************/ #include "vindividualmeasurements.h" const QString VIndividualMeasurements::AttrIgnore = QStringLiteral("ignore"); const QString VIndividualMeasurements::AttrName = QStringLiteral("name"); const QString VIndividualMeasurements::AttrM_number = QStringLiteral("m_number"); const QString VIndividualMeasurements::AttrGui_text = QStringLiteral("gui_text"); const QString VIndividualMeasurements::AttrValue = QStringLiteral("value"); const QString VIndividualMeasurements::AttrDescription = QStringLiteral("description"); const QString VIndividualMeasurements::TagLang = QStringLiteral("lang"); const QString VIndividualMeasurements::TagFamily_name = QStringLiteral("family-name"); const QString VIndividualMeasurements::TagGiven_name = QStringLiteral("given-name"); const QString VIndividualMeasurements::TagBirth_date = QStringLiteral("birth-date"); const QString VIndividualMeasurements::TagSex = QStringLiteral("sex"); const QString VIndividualMeasurements::TagUnit = QStringLiteral("unit"); VIndividualMeasurements::VIndividualMeasurements(VContainer *data):VDomDocument(data) { } Valentina::Units VIndividualMeasurements::Unit() const { const QString unit = UniqueTagText(TagUnit, UnitCM); return VDomDocument::StrToUnits(unit); } void VIndividualMeasurements::setUnit(const Valentina::Units &unit) { const QDomNodeList nodeList = this->elementsByTagName(AttrUnit); if (nodeList.isEmpty()) { qWarning()<<"Can't save measurements units"<elementsByTagName(tag); if (nodeList.isEmpty()) { qWarning()<<"Measurement" << tag <<"doesn't exist"<AddMeasurement(name, VMeasurement(value/10.0, gui_text, description, tag)); if (m_number.isEmpty()) { qWarning()<<"Can't find language-independent measurement name for "<< tag; return; } else { VMeasurement m(value/10.0, gui_text, description, tag); m.setVirtual(true); data->AddMeasurement(m_number, m); } } else//Cm or inch. { data->AddMeasurement(name, VMeasurement(value, gui_text, description, tag)); if (m_number.isEmpty()) { qWarning()<<"Can't find language-independent measurement name for "<< tag; return; } else { VMeasurement m(value, gui_text, description, tag); m.setVirtual(true); data->AddMeasurement(m_number, m); } } } } } } QString VIndividualMeasurements::Language() { return UniqueTagText(TagLang, "en"); } QString VIndividualMeasurements::FamilyName() { return UniqueTagText(TagFamily_name, ""); } QString VIndividualMeasurements::GivenName() { return UniqueTagText(TagGiven_name, ""); } QString VIndividualMeasurements::BirthDate() { return UniqueTagText(TagBirth_date, ""); } QString VIndividualMeasurements::Sex() { return UniqueTagText(TagSex, ""); }