Files
UnrealEngineUWP/Engine/Source/Developer/ToolMenus/Public/ToolMenuSection.h
sebastian arleryd 74696d30d1 Add Documentation Strings to User-Facing ToolMenus Code
This adds in-code documentation strings to a few more ToolMenus APIs. The goal is not full coverage but to hit the most commonly used bits and the ones new users most likely run into first.

#jira UE-193566
#rb Rex.Hill

[CL 29372914 by sebastian arleryd in ue5-main branch]
2023-11-02 14:18:27 -04:00

135 lines
6.7 KiB
C++

// Copyright Epic Games, Inc. All Rights Reserved.
#pragma once
#include "CoreMinimal.h"
#include "ToolMenuDelegates.h"
#include "ToolMenuEntry.h"
#include "Misc/Attribute.h"
#include "ToolMenuSection.generated.h"
UCLASS(Blueprintable)
class TOOLMENUS_API UToolMenuSectionDynamic : public UObject
{
GENERATED_BODY()
public:
UFUNCTION(BlueprintImplementableEvent, Category = "Tool Menus")
void ConstructSections(UToolMenu* Menu, const FToolMenuContext& Context);
};
USTRUCT(BlueprintType)
struct TOOLMENUS_API FToolMenuSection
{
GENERATED_BODY()
public:
FToolMenuSection();
void InitSection(const FName InName, const TAttribute< FText >& InLabel, const FToolMenuInsert InPosition);
FToolMenuEntry& AddEntryObject(UToolMenuEntryScript* InObject);
FToolMenuEntry& AddEntry(const FToolMenuEntry& Args);
/**
* Add a menu entry to this section.
*
* @param InName The FName of the added entry used to identify it.
* @param InLabel The user-visible label of this entry.
* @param InToolTip The user-visible tooltip of this entry.
* @param InIcon The user-visible icon of this entry.
* @param InAction The delegates to call to make this entry interactive. Supports more than just on-click delegates. See FToolUIActionChoice for more information.
* @param UserInterfaceActionType The type of user interface element (such as a checkbox) to use for this entry. See EUserInterfaceActionType for more options.
* @return A reference to the added menu entry.
*/
FToolMenuEntry& AddMenuEntry(const FName InName, const TAttribute<FText>& InLabel, const TAttribute<FText>& InToolTip, const TAttribute<FSlateIcon>& InIcon, const FToolUIActionChoice& InAction, const EUserInterfaceActionType UserInterfaceActionType = EUserInterfaceActionType::Button, const FName InTutorialHighlightName = NAME_None);
FToolMenuEntry& AddMenuEntry(const TSharedPtr< const FUICommandInfo >& InCommand, const TAttribute<FText>& InLabelOverride = TAttribute<FText>(), const TAttribute<FText>& InToolTipOverride = TAttribute<FText>(), const TAttribute<FSlateIcon>& InIconOverride = TAttribute<FSlateIcon>(), const FName InTutorialHighlightName = NAME_None, const TOptional<FName> InNameOverride = TOptional<FName>());
FToolMenuEntry& AddMenuEntry(const FName InNameOverride, const TSharedPtr< const FUICommandInfo >& InCommand, const TAttribute<FText>& InLabelOverride = TAttribute<FText>(), const TAttribute<FText>& InToolTipOverride = TAttribute<FText>(), const TAttribute<FSlateIcon>& InIconOverride = TAttribute<FSlateIcon>(), const FName InTutorialHighlightName = NAME_None);
FToolMenuEntry& AddMenuEntryWithCommandList(const TSharedPtr<const FUICommandInfo>& InCommand, const TSharedPtr<const FUICommandList>& InCommandList, const TAttribute<FText>& InLabelOverride = TAttribute<FText>(), const TAttribute<FText>& InToolTipOverride = TAttribute<FText>(), const TAttribute<FSlateIcon>& InIconOverride = TAttribute<FSlateIcon>(), const FName InTutorialHighlightName = NAME_None, const TOptional<FName> InNameOverride = TOptional<FName>());
FToolMenuEntry& AddDynamicEntry(const FName InName, const FNewToolMenuSectionDelegate& InConstruct);
FToolMenuEntry& AddDynamicEntry(const FName InName, const FNewToolMenuDelegateLegacy& InConstruct);
UE_DEPRECATED(4.26, "AddMenuSeparator has been deprecated. Use AddSeparator instead.")
FToolMenuEntry& AddMenuSeparator(const FName InName);
FToolMenuEntry& AddSeparator(const FName InName);
/**
* Add a sub-menu to this section.
*
* @param InName The FName to use for identifying this sub-menu. Must be unique within the section.
* @param InLabel The user-visible label to use for this sub-menu.
* @param InToolTip The user-visible tooltip to use for this sub-menu.
* @param InMakeMenu The delegate to call to construct the sub-menu. This delegate is called when the user clicks the sub-menu entry.
* @param InAction The delegates to use to make this menu entry interactive.
* @param InUserInterfaceActionType The type of user interface element (such as a checkbox) to use for this entry.
* @param bInOpenSubMenuOnClick Whether or not the sub-menu entry opens when it is hovered or only when clicked.
* @param InIcon The user-visible icon to use for this sub-menu.
* @param bShouldCloseWindowAfterMenuSelection Whether or not the sub-menu should close after one of its entries is clicked.
* @return A reference to the menu entry for the added sub-menu.
*/
FToolMenuEntry& AddSubMenu(const FName InName, const TAttribute<FText>& InLabel, const TAttribute<FText>& InToolTip, const FNewToolMenuChoice& InMakeMenu, const FToolUIActionChoice& InAction, const EUserInterfaceActionType InUserInterfaceActionType, bool bInOpenSubMenuOnClick = false, const TAttribute<FSlateIcon>& InIcon = TAttribute<FSlateIcon>(), const bool bShouldCloseWindowAfterMenuSelection = true);
FToolMenuEntry& AddSubMenu(const FName InName, const TAttribute<FText>& InLabel, const TAttribute<FText>& InToolTip, const FNewToolMenuChoice& InMakeMenu, bool bInOpenSubMenuOnClick = false, const TAttribute<FSlateIcon>& InIcon = TAttribute<FSlateIcon>(), const bool bShouldCloseWindowAfterMenuSelection = true, const FName InTutorialHighlightName = NAME_None);
FToolMenuEntry& AddSubMenu(const FName InName, const FToolUIActionChoice& InAction, const TSharedRef<SWidget>& InWidget, const FNewToolMenuChoice& InMakeMenu, bool bShouldCloseWindowAfterMenuSelection = true);
template <typename TContextType>
TContextType* FindContext() const
{
return Context.FindContext<TContextType>();
}
FToolMenuEntry* FindEntry(const FName InName);
const FToolMenuEntry* FindEntry(const FName InName) const;
private:
void InitGeneratedSectionCopy(const FToolMenuSection& Source, FToolMenuContext& InContext);
int32 RemoveEntry(const FName InName);
int32 RemoveEntriesByOwner(const FToolMenuOwner InOwner);
int32 IndexOfBlock(const FName InName) const;
int32 FindBlockInsertIndex(const FToolMenuEntry& InBlock) const;
bool IsNonLegacyDynamic() const;
bool IsRegistering() const;
friend class UToolMenuSectionExtensions;
friend class UToolMenus;
friend class UToolMenu;
public:
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
FName Name;
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
FToolMenuOwner Owner;
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
TArray<FToolMenuEntry> Blocks;
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
FToolMenuInsert InsertPosition;
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
FToolMenuContext Context;
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Tool Menus")
TObjectPtr<UToolMenuSectionDynamic> ToolMenuSectionDynamic;
TAttribute<FText> Label;
FNewSectionConstructChoice Construct;
private:
bool bIsRegistering;
bool bAddedDuringRegister;
};