Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Using MvxCommand With CommandParameter binding

I'm trying using fire MvxCommand with CommandParameter, but faced with following problem: MyView.axml contains:

<LinearLayout
    android:orientation="horizontal"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button1"
        local:MvxBind="Click MyCommand, CommandParameter=foo" />
    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button2"
        local:MvxBind="Click MyCommand, CommandParameter=bar" />
</LinearLayout>

MyViewModel.cs:

public class MyViewModel : MvxViewModel
{
    public ICommand MyCommand { get; private set; }

    public MyViewModel()
    {                                    // param is null
      MyCommand = new MvxCommand<string>(param =>
      {
          if (param == "foo")               
          {
            // do something
          }
          else if (param == "bar")
          {
            // do something else
          }
      });
    }
}

But when I check param variable is null.

What I'm doing wrong?

like image 950
Eugene Smykov Avatar asked Jun 21 '13 11:06

Eugene Smykov


2 Answers

I was doing CommandParameter coding today and you need to do couple of fixes. The axml code should contain CommandParameter='yourParameter' it looks like this:

<LinearLayout
android:orientation="horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button1"
    local:MvxBind="Click MyCommand, CommandParameter='foo'" />
<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button2"
    local:MvxBind="Click MyCommand, CommandParameter='bar'" />

Even if you want to catch an Integer you still need to pass this in single quotation marks as this: CommandParameter='1234'

In C# code the most important thing is remove MvxCommand from constructor. This should be treated as Property.

public class MyViewModel : MvxViewModel
{
    public MyViewModel() { }

    public MvxCommand<string> MyCommand
    {
        get
        {
            return new MvxCommand<string>(param => 
            {
                if (param == "foo")
                {
                    // do something
                }
                else if (param == "bar")
                {
                    // do something else
                }
            });
        }
    }
}

This was done in MvvmCross6. It should work fine with previous versions.

like image 170
D. Kolowicz Avatar answered Oct 19 '22 21:10

D. Kolowicz


Your code is working for me on the Head of my source tree.

But this functionality is only two weeks old.

My guess is that this feature either didn't make it into the release that you are working with or there was a bug with it.

Can you check your debug trace for this binding? Is there any information there?

  • If the trace suggests that CommandParameter is an unknown symbol then my guess is that you will need to either build the latest source yourself - or to wait for a new release.
  • If the trace suggests something else then you may be able to patch the problem during setup.

One thing I know we did fix was a value converter issue where the Cirrious.MvvmCross.Binding.dll based ValueConverter's weren't being just by overriding Setup.ValueConverterAssemblies to register the ValueConverter required for this CommandParameter

like image 33
Stuart Avatar answered Oct 19 '22 19:10

Stuart