// SPDX-License-Identifier: LGPL-2.1-or-later /*************************************************************************** * Copyright (c) 2016 Stefan Tröger * * * * This file is part of the FreeCAD CAx development system. * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Library General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * * This library 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 Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this library; see the file COPYING.LIB. If not, * * write to the Free Software Foundation, Inc., 59 Temple Place, * * Suite 330, Boston, MA 02111-1307, USA * * * ***************************************************************************/ #include #include #include #include #include #include #include "ViewProviderAttachExtension.h" #include "TaskAttacher.h" using namespace PartGui; EXTENSION_PROPERTY_SOURCE(PartGui::ViewProviderAttachExtension, Gui::ViewProviderExtension) ViewProviderAttachExtension::ViewProviderAttachExtension() { initExtensionType(ViewProviderAttachExtension::getExtensionClassTypeId()); } QIcon ViewProviderAttachExtension::extensionMergeColorfullOverlayIcons(const QIcon& orig) const { QIcon mergedicon = orig; if (getExtendedViewProvider()->getObject()->hasExtension( Part::AttachExtension::getExtensionClassTypeId() )) { auto* attach = getExtendedViewProvider()->getObject()->getExtensionByType(); if (attach) { if (!attach->isAttacherActive()) { static QPixmap px(Gui::BitmapFactory().pixmapFromSvg("Part_Detached", QSize(10, 10))); mergedicon = Gui::BitmapFactoryInst::mergePixmap( mergedicon, px, Gui::BitmapFactoryInst::BottomLeft ); } } } return mergedicon; } void ViewProviderAttachExtension::extensionUpdateData(const App::Property* prop) { auto obj = getExtendedViewProvider()->getObject(); if (obj && obj->hasExtension(Part::AttachExtension::getExtensionClassTypeId())) { auto* attach = obj->getExtensionByType(); if (attach) { if (prop == &(attach->AttachmentSupport) || prop == &(attach->MapMode) || prop == &(attach->MapPathParameter) || prop == &(attach->MapReversed) || prop == &(attach->AttachmentOffset) || prop == &(attach->AttacherType)) { getExtendedViewProvider()->signalChangeIcon(); // signal icon change } } } } void ViewProviderAttachExtension::extensionSetupContextMenu(QMenu* menu, QObject*, const char*) { bool attach = getExtendedViewProvider()->getObject()->hasExtension( Part::AttachExtension::getExtensionClassTypeId() ); if (attach) { // toggle command to display components Gui::ActionFunction* func = new Gui::ActionFunction(menu); QAction* act = menu->addAction(QObject::tr("Attachment Editor")); if (Gui::Control().activeDialog()) { act->setDisabled(true); } func->trigger(act, [this]() { this->showAttachmentEditor(); }); } } void ViewProviderAttachExtension::showAttachmentEditor( std::function onAccept, std::function onReject ) { if (Gui::Control().activeDialog()) { Gui::Control().closeDialog(); } TaskDlgAttacher* task = new TaskDlgAttacher(getExtendedViewProvider(), true, onAccept, onReject); Gui::Control().showDialog(task); } namespace Gui { EXTENSION_PROPERTY_SOURCE_TEMPLATE( PartGui::ViewProviderAttachExtensionPython, PartGui::ViewProviderAttachExtension ) // explicit template instantiation template class PartGuiExport ViewProviderExtensionPythonT; } // namespace Gui