From 187d33fea08c90caef660aa6b5142739e43dccb5 Mon Sep 17 00:00:00 2001
From: Dimo Dimov <961014+dimodi@users.noreply.github.com>
Date: Tue, 23 Sep 2025 11:53:40 +0300
Subject: [PATCH] kb(Diagram): Add new KB for Diagram shape text below the
image
---
components/diagram/shapes.md | 2 +-
.../diagram-show-shape-text-below-image.md | 134 ++++++++++++++++++
2 files changed, 135 insertions(+), 1 deletion(-)
create mode 100644 knowledge-base/diagram-show-shape-text-below-image.md
diff --git a/components/diagram/shapes.md b/components/diagram/shapes.md
index 90aa6be5d..73aa5322e 100644
--- a/components/diagram/shapes.md
+++ b/components/diagram/shapes.md
@@ -414,7 +414,7 @@ When using a visual function, the Diagram ignores all Shape parameters in the Ra
> This section links to the documentation of Kendo UI for jQuery. The Telerik Diagram for Blazor is not a wrapper of the Kendo UI Diagram. However, both components use the same client-side rendering engine. When the Kendo UI documentation mentions the `kendo.dataviz.diagram` JavaScript namespace, you must use `TelerikBlazor.DiagramCommon` instead.
-In addition to the following example, also check this [Blazor Diagram demo](https://demos.telerik.com/blazor-ui/diagram/overview), which uses a visual function.
+In addition to the following example, also check the [Blazor Diagram Overview demo](https://demos.telerik.com/blazor-ui/diagram/overview) and the [Show Diagram Shape Text Below Image](slug:diagram-kb-show-shape-text-below-image) knowledge base article. Both use a visual function.
>caption Using Diagram Shape visual function
diff --git a/knowledge-base/diagram-show-shape-text-below-image.md b/knowledge-base/diagram-show-shape-text-below-image.md
new file mode 100644
index 000000000..e40d709b1
--- /dev/null
+++ b/knowledge-base/diagram-show-shape-text-below-image.md
@@ -0,0 +1,134 @@
+---
+title: Show Diagram Shape Text Below Image
+description: Learn how to display shape text below the shape image in a Telerik Blazor Diagram component.
+type: how-to
+page_title: How to Show Shape Text Below the Image in Telerik Diagram for Blazor
+slug: diagram-kb-show-shape-text-below-image
+tags: telerik, blazor, diagram
+ticketid: 1698784
+res_type: kb
+---
+
+## Environment
+
+
+
+
+ Product |
+ Diagram for Blazor |
+
+
+
+
+## Description
+
+This KB answers the following questions:
+
+* How to show the text label of a Diagram Shape below the image? By default, the text overlays the image, making it hard to read.
+* Can the Shape text be positioned under the image without using visual functions with JavaScript?
+* How to display and position the text in a Diagram Shape below the image?
+
+## Solution
+
+To rearrange the text labels and images in the Blazor Diagram Shapes, use the [`Visual` parameter of the `` or `` tag](slug:diagram-shapes#visual-function). This will either affect all Shapes or a specific Shape. The associated JavaScript function may position the image and text with [`x` and `y` properties](https://www.telerik.com/kendo-jquery-ui/documentation/api/javascript/dataviz/diagram/text_block), but usually, the better option is to use a [`Layout` primitive](https://www.telerik.com/kendo-jquery-ui/documentation/api/javascript/dataviz/diagram/layout) as in the example below.
+
+>caption Arrange Diagram Shape image and text one below the other
+
+````RAZOR
+
+
+
+
+
+
+
+
+ @foreach (DiagramShapeModel diagramShape in DiagramData)
+ {
+
+ }
+
+
+
+ @foreach (DiagramShapeModel diagramShape in DiagramData)
+ {
+ if (!string.IsNullOrEmpty(diagramShape.ParentId))
+ {
+
+ }
+ }
+
+
+
+@* Move JavaScript code to a separate JS file *@
+
+
+@code {
+ private List DiagramData { get; set; } = new()
+ {
+ new DiagramShapeModel() { Id = "shape-1", Title = "Shape 1 Title" },
+ new DiagramShapeModel() { Id = "shape-2", ParentId = "shape-1", Title = "Shape 2 Title" },
+ new DiagramShapeModel() { Id = "shape-3", ParentId = "shape-1", Title = "Shape 3 Title" },
+ };
+
+ public class DiagramShapeModel
+ {
+ public string Id { get; set; } = string.Empty;
+ public string ParentId { get; set; } = string.Empty;
+ public string Title { get; set; } = "Default Shape Title";
+ public string Source { get; set; } = Base64SvgImage;
+ }
+
+ private const string Base64SvgImage = "";
+}
+````
+
+## See Also
+
+* [Diagram Shapes](slug:diagram-shapes)
+* [Diagram Demo with Shape Visual](https://demos.telerik.com/blazor-ui/diagram/overview)