diff --git a/src/PrpShop/Main.cpp b/src/PrpShop/Main.cpp index 77d2f4a..a300ce0 100644 --- a/src/PrpShop/Main.cpp +++ b/src/PrpShop/Main.cpp @@ -439,6 +439,26 @@ void PrpShopMain::treeContextMenu(const QPoint& pos) } else if (item->type() == QPlasmaTreeItem::kTypeKO) { menu.addAction(fActions[kTreeEdit]); menu.addAction(fActions[kTreeEditPRC]); + QMenu* editAsMenu = menu.addMenu(tr("Edit A&s")); + editAsMenu->setEnabled(false); + for (short type : pqGetValidKOTypes()) { + if (item->obj()->ClassInstance(type)) { + QAction* action = editAsMenu->addAction( + pqGetTypeIcon(type), + pqGetFriendlyClassName(type), + [this, item, type]() { + editCreatable(item->obj(), type); + } + ); + if (type == item->obj()->ClassIndex()) { + editAsMenu->setDefaultAction(action); + } else { + // Enable the Edit As submenu only if it has at least one "interesting" entry, + // i. e. not just the default editor. + editAsMenu->setEnabled(true); + } + } + } menu.addAction(fActions[kTreeEditHex]); menu.addAction(fActions[kTreePreview]); menu.addAction(fActions[kTreeViewTargets]); diff --git a/src/PrpShop/PRP/QCreatable.cpp b/src/PrpShop/PRP/QCreatable.cpp index ac822f4..44abe49 100644 --- a/src/PrpShop/PRP/QCreatable.cpp +++ b/src/PrpShop/PRP/QCreatable.cpp @@ -162,8 +162,6 @@ QCreatable* pqMakeCreatableForm(plCreatable* pCre, QWidget* parent, int forceTyp return new QDynamicTextMap(pCre, parent); case kFadeOpacityMod: return new QFadeOpacityMod(pCre, parent); - case kInterfaceInfoModifier: - return new QInterfaceInfoModifier(pCre, parent); case kGMaterial: return new QMaterial(pCre, parent); case kGUIButtonMod: @@ -206,6 +204,8 @@ QCreatable* pqMakeCreatableForm(plCreatable* pCre, QWidget* parent, int forceTyp return new QGUIUpDownPairMod(pCre, parent); case kImageLibMod: return new QImageLibMod(pCre, parent); + case kInterfaceInfoModifier: + return new QInterfaceInfoModifier(pCre, parent); case kLayer: return new QLayer(pCre, parent); case kLayerAnimation: diff --git a/src/PrpShop/QPlasmaUtils.cpp b/src/PrpShop/QPlasmaUtils.cpp index 0f53a4d..89f271b 100644 --- a/src/PrpShop/QPlasmaUtils.cpp +++ b/src/PrpShop/QPlasmaUtils.cpp @@ -590,18 +590,18 @@ std::vector pqGetValidKOTypes() k2WayWinAudible, kAudible, kAudibleNull, kAudioInterface, kAvLadderMod, kCollisionDetector, kCoordinateInterface, kCubicEnvironmap, kDetectorModifier, kDirectShadowMaster, kDrawInterface, kDynamicTextMap, - kFadeOpacityMod, kGUIButtonMod, kGUICheckBoxCtrl, kGUIClickMapCtrl, + kFadeOpacityMod, kGMaterial, kGUIButtonMod, kGUICheckBoxCtrl, kGUIClickMapCtrl, kGUIDialogMod, kGUIDragBarCtrl, kGUIDraggableMod, kGUIDynDisplayCtrl, kGUIEditBoxMod, kGUIKnobCtrl, kGUIListBoxMod, kGUIMenuItem, kGUIMultiLineEditCtrl, kGUIPopUpMenu, kGUIProgressCtrl, kGUIRadioGroupCtrl, kGUISkin, kGUITextBoxMod, kGUIUpDownPairMod, kImageLibMod, kInterfaceInfoModifier, kLayer, kLayerAnimation, kLayerAVI, kLayerBink, kLayerDepth, kLayerLinkAnimation, kLayerMovie, - kLayerSDLAnimation, kGMaterial, kMaintainersMarkerModifier, kMipmap, + kLayerSDLAnimation, kMaintainersMarkerModifier, kMipmap, kMsgForwarder, kMultistageBehMod, kOneShotMod, kPanicLinkRegion, kPickingDetector, kPointShadowMaster, kPythonFileMod, kSceneNode, kSceneObject, kSeekPointMod, kShadowMaster, kSimulationInterface, kSound, - kSoundBuffer, kSpawnModifier, kSubworldRegionDetector, kWinAudible, + kSoundBuffer, kSpawnModifier, kSubworldRegionDetector, kSynchedObject, kWinAudible, kWin32LinkSound, kWin32Sound, kWin32StaticSound, kWin32StreamingSound, }; static size_t s_numTypes = sizeof(s_typeList) / sizeof(s_typeList[0]);