TECHNOLOGIES
FORUMS
JOBS
BOOKS
EVENTS
INTERVIEWS
Live
MORE
LEARN
Training
CAREER
MEMBERS
VIDEOS
NEWS
BLOGS
Sign Up
Login
No unread comment.
View All Comments
No unread message.
View All Messages
No unread notification.
View All Notifications
Answers
Post
An Article
A Blog
A News
A Video
An EBook
An Interview Question
Ask Question
Forums
Monthly Leaders
Forum guidelines
Pavan Kumar
NA
68
15.1k
multiselection combobox in wpf using mvvm
Oct 30 2014 2:33 AM
I am using WPF MVVM model in my project using C#.Net.
I am trying to bind data from DB to multiselection combobox using MVVM.
Data binded in Itemsource collection. But not displayed in multiselection combobox.
Also based on the selection data should store in DB (SQL Server). We are using entity framework to save data.
Herewith I have attacehd my code. Please guide.
I have attached my XAML and ViewModel Code for your reference.
XAML Code:
==========
<ComboBox Name="cmbDlDashletName" Style="{StaticResource VisaBirdComboBoxStyle}" SelectedValuePath="DashletName" SelectedValue="{Binding DashletName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged, ValidatesOnDataErrors=True,NotifyOnValidationError=True}" ItemsSource="{Binding WidgetCollectionProperty}" IsEnabled="{Binding Path=PropertyStates[readOnly].IsEditable}" Height="25" Width="355" HorizontalAlignment="Left" Grid.Row="2" Grid.Column="1" >
<i:Interaction.Triggers>
<i:EventTrigger EventName="SelectionChanged">
<i:InvokeCommandAction Command="{Binding SelectionChangedCommand}"/>
</i:EventTrigger>
</i:Interaction.Triggers>
<ComboBox.ItemTemplate>
<DataTemplate>
<!--<StackPanel Orientation="Horizontal">-->
<CheckBox Name="chkDashlet" Content="{Binding Path=DashletName}" IsChecked="{Binding DashletAccess, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Tag="{RelativeSource FindAncestor, AncestorType={x:Type ComboBoxItem}}" >
<!--<TextBlock Text="{Binding DashletName}" VerticalAlignment="Center"/>-->
<i:Interaction.Triggers>
<i:EventTrigger EventName="Checked">
<i:InvokeCommandAction Command="{Binding CheckboxCheckedCommand}" />
</i:EventTrigger>
</i:Interaction.Triggers>
<!--</StackPanel>-->
</CheckBox>
</DataTemplate>
</ComboBox.ItemTemplate>
</ComboBox>
View Model:
==========
WindowElement winElement = GetWindowElement.GetElement(Collection.DashletFormName);
if (DataValidator.IsValid(winElement))
{
if (this.ViewMode == ViewModeType.Add)
{
bool doesExistAlready = DashletCollectionProperty.Count(x => x.DashletName == DashletName && x.DashletUserId == DashletUserId) > 0;
if (!doesExistAlready)
{
foreach (var Values in DashletCollectionProperty)
{
Values.UserName = UserCollection.Where(x => x.User_UserId == DashletUserId).Select(a => a.User_UserLoginId).Single(); //UserName;
Values.DashletName = DashletName;
Values.CreatedBy = LoginUserDetails.UserId;
Values.ModifiedUserId = LoginUserDetails.UserId;
Values.DateEntered = DateTime.Now;
Values.DateModified = DateTime.Now;
Values.DateModifiedUtc = DateTime.Now;
Values.DashletUserId = DashletUserId;
DashletAccess = false;
if (DashletAccess == false)
{
User_Dashlet_Type = User_Dashlet_Type + "0,";
DashletUserId = DashletUserId;
}
else
{
User_Dashlet_Type = User_Dashlet_Type + "1,";
DashletUserId = DashletUserId;
}
User_Dashlet_Type = User_Dashlet_Type.Remove(User_Dashlet_Type.Length - 1);
DashletUserId = DashletUserId.Remove(DashletUserId.Length - 1);
Values.User_Dashlet_Type = User_Dashlet_Type;
DashletCollection.Add(Values);
ResultInfo = VisaBirdRestMethods.VisaBirdSendData("CRUD_Operations_Dashlet_Rest/Insert" + DEModeEnum.Insert, Values, typeof(DEDashlet)) as DEErrorProvider;
if (ResultInfo.ErrorResult)
{
RestGetDashletList();
VisaBirdMessage.showMessage(Collection.DashletData + ContentResource["DetailsView_SaveSuccess_Validation"].ToString(), ContentResource["DetailsView_Information"].ToString(), DialogButton.Ok, 500);
}
else
{
VisaBirdMessage.showMessage(Collection.DashletData + ContentResource["DetailsView_SaveError_Validation"].ToString(), ContentResource["DetailsView_Information"].ToString(), DialogButton.Ok, 500);
}
Please advise.
Reply
Answers (
0
)
User Control inside the Tabitem in wpf using mvvm
Change background color