Views
The AIPrompt provides predefined and custom views that you set through the Views() configuration.
Prompt View
The Prompt view contains the input where the user enters the prompt, the list of available prompt suggestions, and the Generate button to submit the prompt.
To define a collection of prompt suggestions, use the PromptSuggestions() option.
The example below shows how to configure the built-in Prompt view and specify the prompt suggestions that must be displayed in the view.
    @(Html.Kendo().AIPrompt()
        .Name("aiprompt")
        .Views(views =>
        {
            views.Add().Type(ViewType.Prompt)
            .PromptSuggestions(new string[] { "Out of office template", "LinkedIn post for well-being" });
        })
    )Output View
The Output view is the place where the output of the AI request is displayed. The view contains a list of cards, where each card has the following elements:
- Header—Shows the prompt text.
- Body—Contains the generated prompt output.
- Actions—Displays quick actions like a copy-output button, a retry-output button, and an output rating (like and dislike reactions).
The following example demonstrates how to specify the Output view as active when the AIPrompt loads and how to hide the built-in output rating that is visible by default.
    @(Html.Kendo().AIPrompt()
        .Name("aiprompt")
        .ActiveView(1)
        .Views(views =>
        {
            views.Add().Type(ViewType.Prompt);
            views.Add().Type(ViewType.Output);
        })
    )Commands View
The Commands view is a predefined view where you can define commands that the user can execute, for example, Change the formality of the output, Select output language, and more.
The commands are rendered in the view as a list of items and sub-items. To define the desired commands, use the PromptCommands() option.
Clicking a specified command triggers the CommandExecute event. You can handle the event and execute the respective action by using client-side logic.
The example below shows how to configure the Commands view and specify a custom command that modifies the already generated output when clicked.
    @(Html.Kendo().AIPrompt()
        .Name("aiprompt")
        .Events(ev => ev.CommandExecute("onCommandExecute")) // Handle the 'CommandExecute' event to execute the command logic when it is clicked.
        .Views(views =>
        {
            views.Add().Type(ViewType.Prompt)
            .PromptSuggestions(new string[] { "Out of office (template)", "LinkedIn post for well-being" });
            views.Add().Type(ViewType.Commands)
            .PromptCommands(commands =>
            {
                commands.Add().Id("1").Text("Extend").Icon("arrows-left-right");
            });
        })
    )Custom View
You can create a custom view in the AIPrompt component and add custom elements and components.
Define the custom view through the Views() configuration and set the Type() option to ViewType.Custom. Then, use the following options to define the view content:
- ButtonTextand- ButtonIcon—Set the text and icon of the Toolbar item rendered for the custom view.
- ViewTemplateand- FooterTemplate—Specify the templates for the view content and footer.
- InitializeComponents—Allows you to pass a JavaScript function that executes when the view is rendered. You can initialize widgets in the view content.
The following example demonstrates how to create a custom view that contains a button.
    @(Html.Kendo().AIPrompt()
        .Name("aiprompt")
        .Views(views =>
        {
            views.Add().Type(ViewType.Custom)
            .Name("custom")
            .ButtonText("Custom View")
            .ButtonIcon("pencil")
            .ViewTemplate("<div><p>Custom View</p></div>")
            .FooterTemplate("<div class='k-actions k-actions-start k-actions-horizontal k-prompt-actions'><button ref-custom-button>Click me</button></div>")
            .InitializeComponents("initializeComponents");
        })
    )