Most likely the Command is being called, but the result is not what you'd expected.
For testing purposes try
member this.SetA =
this.Factory.CommandSync(
fun _ -> System.Windows.MessageBox.Show("TextChanged","RoutedEv") |> ignore)
Note the CommandSync instead of EventValueCommand. No matter how you change the score, a msgbox will pop up.
You could also keep the EventValueCommand
member this.SetA = this.Factory.EventValueCommand(SetA)
and do the same in the update fun
let update score event =
match event with
| IncA -> {score with ScoreA = score.ScoreA + 1}
| DecA -> {score with ScoreA = max (score.ScoreA - 1) 0}
| IncB -> {score with ScoreB = score.ScoreB + 1}
| DecB -> {score with ScoreB = max (score.ScoreB - 1) 0}
| New -> zero
| SetA -> System.Windows.MessageBox.Show("TextChanged","RoutedEv") |> ignore ; score
Getting back to the not what you'd expected part, I assume you want the score in the scoreboard to update, when you change the TextBox.Text value.
As you've noticed there's no (pure) way to bring the TextBox.Text value into the update fun using the current controller.
Due to the fact that the SetX behaviour isn't fix, unlike in the case of the IncX, DecX or New events.
Options:
You could change the signature of the controller to Score -> ScoringEvent -> string option -> Score and use the option value to handle SetX events in the update fun.
You could handle everything in the ViewModel.
The immutable nature of the record forces the use of a OneWay Binding. I would keep it immutable, but you can (de)compose everything in the ViewModel.
Try
ViewModel
type MainViewModel(controller : Score -> ScoringEvent -> Score) as self =
inherit EventViewModelBase<ScoringEvent>()
let scoreA = self.Factory.Backing(<@ self.ScoreA @>, 0)
let scoreB = self.Factory.Backing(<@ self.ScoreB @>, 0)
let updateVM score =
scoreA.Value <- score.ScoreA
scoreB.Value <- score.ScoreB
let eventHandler ev =
updateVM <| controller {ScoreA = scoreA.Value ; ScoreB = scoreB.Value} ev
do
self.EventStream
|> Observable.add eventHandler
member this.IncA = this.Factory.EventValueCommand(IncA)
member this.DecA = this.Factory.EventValueCommandChecked(DecA, (fun _ -> this.ScoreA > 0), [ <@@ this.ScoreA @@> ])
member this.IncB = this.Factory.EventValueCommand(IncB)
member this.DecB = this.Factory.EventValueCommandChecked(DecB, (fun _ -> this.ScoreB > 0), [ <@@ this.ScoreB @@> ])
member this.NewGame = this.Factory.EventValueCommand(New)
member __.ScoreA
with get() = scoreA.Value
and set v = scoreA.Value <- v
member __.ScoreB
with get() = scoreB.Value
and set v = scoreB.Value <- v
XAML
<DockPanel LastChildFill="True">
<StackPanel DockPanel.Dock="Bottom" Height="75" Orientation="Horizontal" Background="#FF3A3A3A">
<Button Height="70" Width="70" Margin="2" Command="{Binding NewGame}">
<TextBlock Text="New" FontSize="18"></TextBlock>
</Button>
<TextBox Text="{Binding ScoreA, UpdateSourceTrigger=PropertyChanged}"
Margin="2" FontSize="18" HorizontalContentAlignment="Center" VerticalContentAlignment="Center">
</TextBox>
</StackPanel>
<Grid>
<Grid.RowDefinitions>
<RowDefinition />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<Border Background="#FF024D70" Grid.Column="0">
<Grid>
<Viewbox>
<Label Content="{Binding ScoreA}" ContentStringFormat="D2" FontFamily="Lucida Console"></Label>
</Viewbox>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Center">
<Button Command="{Binding DecA}" Height="70" Width="70" VerticalAlignment="Bottom" Opacity="0.5" Margin="20">
<TextBlock Text="-" FontSize="36" Height="60"></TextBlock>
</Button>
<Button Command="{Binding IncA}" Height="70" Width="70" VerticalAlignment="Bottom" Opacity="0.5" Margin="20">
<TextBlock Text="+" FontSize="36" Height="60"></TextBlock>
</Button>
</StackPanel>
</Grid>
</Border>
<Border Background="#FF7E0E03" Grid.Column="1">
<Grid>
<Viewbox>
<Label Content="{Binding ScoreB}" ContentStringFormat="D2" FontFamily="Lucida Console"></Label>
</Viewbox>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Center">
<Button Command="{Binding DecB}" Height="70" Width="70" VerticalAlignment="Bottom" Opacity="0.5" Margin="20">
<TextBlock Text="-" FontSize="36" Height="60"></TextBlock>
</Button>
<Button Command="{Binding IncB}" Height="70" Width="70" VerticalAlignment="Bottom" Opacity="0.5" Margin="20">
<TextBlock Text="+" FontSize="36" Height="60"></TextBlock>
</Button>
</StackPanel>
</Grid>
</Border>
</Grid>
</DockPanel>
Notes
Score.ScoreX changed to ScoreX
Text="{Binding Score.ScoreA, Mode=OneWay}" changed to Text="{Binding ScoreA, UpdateSourceTrigger=PropertyChanged}"
- Removed the
Interaction.Trigger