Hi Admin,
The dropdownlist of autocompletemode is suggest and dropdownlist of dropdownstyle is dropdown.
I have two dropdownlist. First is Category and second details.
First Category data are Green,Red and Orange.
Second Details data are Avocado, Green apple, Green grape, Kiwi, Pear, Honeydew Melon, Raspberry, Strawberry, cherry, Orange, Papaya, Tangerines, Pumpkin and Plum.
When I key in detail dropdownlist start from 'P' and I choose 'Plum' and Category dropdownlist auto change to Red but second dropdownlist automatically choose Strawberry.
If Category choose blank , all dropdownlist reset. If Category choose green, detail dropdownlist need to show green category code of fruit. No need to show all value.
Below my testing coding.
Imports Telerik.WinControls.UI
Public Class RadForm1
Property FolderCodeToUse As Nullable(Of Integer)
Property DocumentTypeCodeToUse As Nullable(Of Integer)
Property DocumentDescriptionToUse As String
Property BlnSuppressFolderCode As Boolean
Property BlnSuppressDocumentTypeCode As Boolean
Property font As New Font("Arial", 14)
Property ListOfDocumentTypes As List(Of DocumentTypes)
Private Sub RadForm1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
ListOfDocumentTypes = New List(Of DocumentTypes)
Dim lstfoldercode As New List(Of DocumentTypes)
Dim fold1 As New DocumentTypes
fold1.FolderCode = 1
fold1.FolderNameText = "Green"
lstfoldercode.Add(fold1)
fold1 = New DocumentTypes
fold1.FolderCode = 2
fold1.FolderNameText = "Red"
lstfoldercode.Add(fold1)
fold1 = New DocumentTypes
fold1.FolderCode = 3
fold1.FolderNameText = "Orange"
lstfoldercode.Add(fold1)
lstfoldercode.Insert(0, New DocumentTypes)
Dim doc1 As New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 1
doc1.DocumentTypeDescription = "Avocado"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 2
doc1.DocumentTypeDescription = "Green apple"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 2
doc1.DocumentTypeDescription = "Green grape"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 3
doc1.DocumentTypeDescription = "Kiwi"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 4
doc1.DocumentTypeDescription = "Pear"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 1
doc1.FolderNameText = "Green"
doc1.DocumentTypeCode = 5
doc1.DocumentTypeDescription = "Honeydew Melon"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 2
doc1.FolderNameText = "Red"
doc1.DocumentTypeCode = 1
doc1.DocumentTypeDescription = "Raspberry"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 2
doc1.FolderNameText = "Red"
doc1.DocumentTypeCode = 6
doc1.DocumentTypeDescription = "Strawberry"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 2
doc1.FolderNameText = "Red"
doc1.DocumentTypeCode = 7
doc1.DocumentTypeDescription = "Cherry"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 3
doc1.FolderNameText = "Orange"
doc1.DocumentTypeCode = 8
doc1.DocumentTypeDescription = "Orange"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 3
doc1.FolderNameText = "Orange"
doc1.DocumentTypeCode = 9
doc1.DocumentTypeDescription = "Papaya"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 3
doc1.FolderNameText = "Orange"
doc1.DocumentTypeCode = 10
doc1.DocumentTypeDescription = "Tangerines"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 3
doc1.FolderNameText = "Orange"
doc1.DocumentTypeCode = 11
doc1.DocumentTypeDescription = "Pumpkin"
ListOfDocumentTypes.Add(doc1)
doc1 = New DocumentTypes
doc1.FolderCode = 2
doc1.FolderNameText = "Red"
doc1.DocumentTypeCode = 12
doc1.DocumentTypeDescription = "Plum"
ListOfDocumentTypes.Add(doc1)
ListOfDocumentTypes.Insert(0, New DocumentTypes)
Me.RadDropDownList2.ValueMember = "DocumentTypeCode"
Me.RadDropDownList2.DisplayMember = "DocumentTypeDescription"
Me.BlnSuppressDocumentTypeCode = True
Me.RadDropDownList2.DataSource = Me.ListOfDocumentTypes.ToList
Me.BlnSuppressDocumentTypeCode = False
Me.RadDropDownList2.Refresh()
For Each item As RadListDataItem In RadDropDownList1.ListElement.Items
item.Font = font
Next
Me.RadDropDownList1.ValueMember = "FolderCode"
Me.RadDropDownList1.DisplayMember = "FolderNameText"
Me.BlnSuppressFolderCode = True
Me.RadDropDownList1.DataSource = lstfoldercode.ToList
Me.BlnSuppressFolderCode = False
Me.RadDropDownList1.Refresh()
For Each item As RadListDataItem In RadDropDownList1.ListElement.Items
item.Font = font
Next
End Sub
Private Sub RadDropDownList1_SelectedValueChanged(sender As Object, e As EventArgs) Handles RadDropDownList1.SelectedValueChanged
Try
If Me.BlnSuppressFolderCode Then
Exit Sub
End If
Dim CategoryCode As Integer = CInt(RadDropDownList1.SelectedValue)
RadDropDownList1.DataSource = Nothing
RadDropDownList1.Refresh()
LoadDetailBasedOnCategory(CategoryCode)
Catch ex As Exception
End Try
End Sub
Private Sub RadDropDownList2_SelectedValueChanged(sender As Object, e As EventArgs) Handles RadDropDownList2.SelectedValueChanged
Try
If Me.BlnSuppressDocumentTypeCode Then
Exit Sub
End If
Dim detailstypeCode As Integer = CInt(RadDropDownList2.SelectedValue)
If detailstypeCode = 0 Then
Exit Sub
End If
Dim categoryCodeSelected As Integer = CInt(RadDropDownList1.SelectedValue)
If categoryCodeSelected = 0 Then
'STEP 5. Find the FolderCode based on the DocumentTypeCode selected
For Each detailTypes1 As DocumentTypes In Me.ListOfDocumentTypes
If detailTypes1.DocumentTypeCode = detailstypeCode Then
categoryCodeSelected = detailTypes1.FolderCode
Exit For
End If
Next
Me.DocumentTypeCodeToUse = detailstypeCode
Me.BlnSuppressFolderCode = True
RadDropDownList1.SelectedValue = categoryCodeSelected
Me.BlnSuppressFolderCode = False
LoadDetailBasedOnCategory(categoryCodeSelected)
Me.BlnSuppressDocumentTypeCode = True
RadDropDownList2.SelectedValue = Me.DocumentTypeCodeToUse.Value
Me.BlnSuppressDocumentTypeCode = False
Me.DocumentTypeCodeToUse = New Nullable(Of Integer)
End If
Catch ex As Exception
End Try
End Sub
Private Sub LoadDetailBasedOnCategory(folderCodeSelected As Integer)
Try
'STEP 1. Get the list of DocumentTypeCode based on the FolderCode
Dim listOfDocumentTypesToShow As New List(Of DocumentTypes)
If folderCodeSelected = 0 Then
For Each documentTypes1 As DocumentTypes In Me.ListOfDocumentTypes.ToList
listOfDocumentTypesToShow.Add(documentTypes1)
Next
ElseIf folderCodeSelected > 0 Then
For Each documentTypes1 As DocumentTypes In Me.ListOfDocumentTypes.ToList
If documentTypes1.FolderCode = folderCodeSelected Then
listOfDocumentTypesToShow.Add(documentTypes1)
End If
Next
End If
'STEP 2. Sort
If listOfDocumentTypesToShow.Count >= 1 Then
listOfDocumentTypesToShow.Sort(Function(x, y)
Dim compare As Integer = 0
If Not String.IsNullOrEmpty(x.DocumentTypeDescription) AndAlso Not String.IsNullOrEmpty(y.DocumentTypeDescription) Then
compare = x.DocumentTypeDescription.CompareTo(y.DocumentTypeDescription)
End If
Return compare
End Function)
'STEP 3. Insert blank first row
listOfDocumentTypesToShow.Insert(0, New DocumentTypes)
End If
'STEP 4. Load data into dropdownlist (suppress any event handler)
RadDropDownList2.ValueMember = "DocumentTypeCode"
RadDropDownList2.DisplayMember = "DocumentTypeDescription"
Me.BlnSuppressDocumentTypeCode = True
RadDropDownList2.DataSource = listOfDocumentTypesToShow.ToList
Me.BlnSuppressDocumentTypeCode = False
RadDropDownList2.Refresh()
For Each ListItem In RadDropDownList2.Items
ListItem.Font = font
Next
Catch ex As Exception
End Try
End Sub
End Class
Public Class DocumentTypes
Property DocumentTypeCode As Integer
Property FolderCode As Integer
Property FolderNameText As String
Property DocumentTypeDescription As String
End Class
Thanks
Moe

Hi,
I am trying to customize the appearance of the list view item and I followed the Shopping Cart List View example at the below location -
https://docs.telerik.com/devtools/winforms/knowledge-base/shopping-cart-lsitview-custom-item
The list view item is divided into two StackLayout elements and each element has further UI elements and buttons. The entire item is divided into 2 halves. I need to define the width of the each StackLayout element such that the element on the left occupies around 70% of the item width and the one on the right to have a 30% width.
Attached is an image for reference which shows the item is split into 2 halves.
A sample code or pointers would be great.
Below is the code for the visual item as well.
using System;using System.Drawing;using System.Windows.Forms;using Telerik.WinControls.UI;using WFAInterplayPOS.Model.DataModel.Cart;using WFAInterplayPOS.Service;namespace WFAInterplayPOS.UserIterface.Restaurant{ public class ActiveCartVisualItem : SimpleListViewVisualItem { // Add button. private RadButtonElement AddButtonElement; // Remove button. private RadButtonElement RemoveButtonElement; // Details layout private StackLayoutElement DetailsStackLayout; // Buttons layout. private StackLayoutElement ButtonsStackLayout; // Title. private LightVisualElement TitleElement; // Viewitem layout. private StackLayoutElement ViewItemLayout; // Amount label. private RadLabelElement AmountLabelElement; /* * Overridden CreateChildElements() * * */ protected override void CreateChildElements() { // base.CreateChildElements(); base.CreateChildElements(); // Viewitem layout. ViewItemLayout = new StackLayoutElement { Orientation = Orientation.Horizontal, ShouldHandleMouseInput = false, NotifyParentOnMouseInput = true, StretchHorizontally = true }; // Build details layout. BuildDetailsLayout(); // Build buttons layout. BuildButtonsLayout(); // Add the visual elements. ViewItemLayout.Children.Add(DetailsStackLayout); ViewItemLayout.Children.Add(ButtonsStackLayout); Children.Add(ViewItemLayout); } /* * BuildDetailsLayout() * * */ private void BuildDetailsLayout() { // Details layout. DetailsStackLayout = new StackLayoutElement { Orientation = Orientation.Vertical, ShouldHandleMouseInput = false, NotifyParentOnMouseInput = true, StretchHorizontally = true, Margin = new Padding(3, 3, 3, 3) }; // Title element. TitleElement = new LightVisualElement { TextAlignment = ContentAlignment.MiddleLeft, StretchHorizontally = true, ShouldHandleMouseInput = false, NotifyParentOnMouseInput = true }; DetailsStackLayout.Children.Add(TitleElement); // Amount label. AmountLabelElement = new RadLabelElement { Margin = new Padding(0, 3, 0, 3), TextAlignment = ContentAlignment.MiddleLeft }; DetailsStackLayout.Children.Add(AmountLabelElement); } /* * BuildButtonsLayout() * * */ private void BuildButtonsLayout() { // Buttons layout. ButtonsStackLayout = new StackLayoutElement { Orientation = Orientation.Horizontal, ShouldHandleMouseInput = false, NotifyParentOnMouseInput = true, StretchHorizontally = true, StretchVertically = true }; // Remove button. RemoveButtonElement = new RadButtonElement { Margin = new Padding(3, 6, 0, 6), Text = "<html><size=13><b>-</b>", StretchVertically = true, }; RemoveButtonElement.Click += RemoveButtonElement_Click; ButtonsStackLayout.Children.Add(RemoveButtonElement); // Add button. AddButtonElement = new RadButtonElement { Margin = new Padding(0, 6, 3, 6), Text = "<html><size=13><b>+</b>", StretchVertically = true, }; AddButtonElement.Click += AddButtonElement_Click; ButtonsStackLayout.Children.Add(AddButtonElement); } /* * AddButtonElement_Click() * * */ private void AddButtonElement_Click(object sender, EventArgs e) { } /* * RemoveButtonElement_Click() * * */ private void RemoveButtonElement_Click(object sender, EventArgs e) { } protected override void SynchronizeProperties() { // base.SynchronizeProperties() base.SynchronizeProperties(); // Other attributes. Text = ""; var data = Data.DataBoundItem as LineItem; TitleElement.Text = "<html><size=10>" + data.quantity + " x " + data.name; AmountLabelElement.Text = "<html><size=10><color=red>" + data.subTotal.amount.ToString("C"); } protected override Type ThemeEffectiveType { get { return typeof(SimpleListViewVisualItem); } } }}
Thanks.

Hi All,
I have added a custom column or cell containing DrodownList -its appearing correctly in view mode.
Now I have below points :
1. On which event of the GridView I can bind the dropdownList.
2. When I select any value (Currently have added some static value in the DropdownList). Once I scroll the grid , the state changes to original state.
3. Some time I noticed that the value i selected for let say row one, the same value is being selected for the the row which is not displayed. after scrolling we can see the same. and the value of 1st row got removed.
4. My requirement is -
Attaching my code of custom cell
class CustomDropCell : GridDataCellElement { private string conString { get; set; } public CustomDropCell(GridViewColumn column, GridRowElement row): base(column, row) { //conString = con; } private StackLayoutPanel panel; private RadDropDownListElement radDropDownList; protected override void CreateChildElements() { base.CreateChildElements(); this.panel = new StackLayoutPanel(); this.panel.Margin = new System.Windows.Forms.Padding(5); this.panel.Orientation = System.Windows.Forms.Orientation.Vertical; this.radDropDownList = new RadDropDownListElement { DropDownStyle = Telerik.WinControls.RadDropDownStyle.DropDownList }; this.radDropDownList.Items.Add("Santosh"); this.radDropDownList.Items.Add("Jha"); this.radDropDownList.Items.Add("Mr"); this.radDropDownList.Items.Add("Kumar"); this.Children.Add(radDropDownList); } protected override void SetContentCore(object value) { GridViewGroupRowInfo row = this.RowInfo as GridViewGroupRowInfo; object cellValue = value; if (cellValue is DBNull || cellValue == null) cellValue = "Mr"; this.radDropDownList.SelectedValue = cellValue; } protected override Type ThemeEffectiveType { get { return typeof(GridDataCellElement); } } public override bool IsCompatible(GridViewColumn data, object context) { return base.IsCompatible(data, context); // return data is CustomDropCellColumn && context is GridDataRowElement; } } public class CustomDropCellColumn : GridViewDataColumn { //private string conString { get; set; } public CustomDropCellColumn(string fieldName) : base(fieldName) { //conString = connectionString; } public override Type GetCellType(GridViewRowInfo row) { if (row is GridViewDataRowInfo) { return typeof(CustomDropCell); } return base.GetCellType(row); } }
Adding the column in Grid in Form Constructor.
CustomDropCellColumn customColumn = new CustomDropCellColumn("Destination Table"); customColumn.MaxWidth = 170; this.radGridViewTable.Columns.Add(customColumn); this.radGridViewTable.Columns["Destination Table"].MinWidth = 165;
I need to use dropdownlist as RadGridView editor
and I have look into this
https://docs.telerik.com/devtools/winforms/controls/dropdown-listcontrol-and-checkeddropdownlist/checkeddropdownlist/how-to/use-as-radgridview-editor
In the sample above,it bound a datasource to the dropdownlist editor,but only handle the display text and control value by overiding the "Value" property.
If I want to bind a datasource with valuemember and displaymember,how to handle them properly?What I expect is to let user choose with the displaymember and valuemember can be saved according to what user choose just like the normal checkeddropdownlist control.


Hi,
I have a TableLayoutPanel that is divided to 3 rows. Each row contains a RadPanel.
Only the middle one is causing transparency issue because it's not filled with controls.
how can I get rid of this issue?
Thanks,
Karoon

Hi all,
I just encountered the most bizarre thing today while using the Rich Text Editor. I upgraded our Telerik DLLs to the most recent one available (2019 R2, 2019.2.618) and it seems like the ability to paste into the Rich Text Editor has been lost all of a sudden. I tried all I could and looked around the forums a bit to no avail. The interesting thing is that when I debug, I can "hit" the CommandExecuting event and I can see that in the code it recognizes that it is a paste command, but the text is not being pasted onto the textbox.
private void RadRichTextEditor1_CommandExecuting(object sender, Telerik.WinForms.Documents.RichTextBoxCommands.CommandExecutingEventArgs e)
{
if (e.Command is PasteCommand)
{
//the event is fired and recognizes that IT IS a PASTE COMMAND, but text is not being pasted onto the textbox
}
}
Has anyone else encountered this before. If so, can anyone point me to the right direction as to why this is happening? Thanks all.
Romel

I have a RadCheckedDropDownList that I am binding a BindingList to it. Some of the items in the list will have the CheckedMember property filled in. However, after the control loads, the items that are checked do not show up in TEXT area of the control. However, if you open the dropdown, you can see items checked. As soon as you uncheck or check an item, all the checked items do show up. This is a problem, I need the items that are checked by default to show up in the TEXT area. Below is my code that I use to bind my list to the control. Am I missing something?
private static void BindList (this RadCheckedDropDownList radDropDownList, BindingList<CheckedListItem> dropDownList, string valueMember = "Key", string displayMember = "Value", string checkedMember = "Checked")
{
radDropDownList.BeginUpdate();
radDropDownList.ValueMember = valueMember;
radDropDownList.DisplayMember = displayMember;
radDropDownList.CheckedMember = checkedMember;
radDropDownList.DataSource = dropDownList;
radDropDownList.EndUpdate();
radDropDownList.SelectedIndex = -1;
}
