MVVM Light RelayCommand Parameters
Asked Answered
T

3

45

I'm having an issue with passing a parameter to a relaycommand using the GalaSoft MVVM Light framework. I know that mvvm light's implementation of relaycommand doesn't use lambda parameters, so I did some research and found a way that people worked around it by doing something like this:

public RelayCommand ProjMenuItem_Edit
{
    get
    {
        if (_projmenuItem_Edit == null)
        {
            //This should work....
            _projmenuItem_Edit = new RelayCommand(ProjEditNode);
        }
        return _projmenuItem_Edit;
    }
}

private void ProjEditNode(object newText)
{
    var str = newText as string;
    OrganLocationViewModel sel = 
        ProjectOrganLocationView.GetExtendedTreeView().GetTopNode();

    //Console.WriteLine(sel.OrganDisplayName);
    sel.OrganDisplayName = str;
}

However, I keep getting an error on the line _projmenuItem_Edit = new RelayCommand(ProjEditNode); that says Argument 1: cannot convert from 'method group' to 'System.Action'

What am I missing?

Tamarra answered 14/3, 2011 at 13:2 Comment(0)
T
90

I believe this will work:

_projmenuItem_Edit = new RelayCommand<object>((txt)=>ProjEditNode(txt));

-- EDIT --

You'll need to define your RelayCommand with the type as well:

e.g.

public RelayCommand<string> myCommand { get; private set; }
myCommand = new RelayCommand<string>((s) => Test(s));

private void Test(string s)
{
    throw new NotImplementedException();
}
Thom answered 14/3, 2011 at 13:14 Comment(6)
I've seen this before and have tried it, but it looks like GalaSoft's RelayCommand doesn't include a RelayCommand<T> implementation? I get this error when I try RelayCommand<T>: Cannot implicitly convert type 'GalaSoft.MvvmLight.Command.RelayCommand<object>' to 'GalaSoft.MvvmLight.Command.RelayCommand'Tamarra
Gah, I tried to edit but was too late... Disregard the previous comment, I forgot to change _projmenuItem_Edit to type RelayCommand<string> too :pTamarra
I updated the answer as well, for anyone else that's running into this. :)Thom
one (unimportant) note - new RelayCommand<object>((txt)=>ProjEditNode(txt)) can just be new RelayCommand<object>(ProjEditNode) - .NET knows how to resolve that method and the parameter being passed to it.Berhley
Damn ! This library needs a decent documentation... awesome stuff wihout knowing it exists is kind of... blazing !Aborigine
A method group should work as well: myCommand = new RelayCommand<string>(Test);Santosantonica
E
4

I don't think that RelayCommand() has a constructor that is not empty. you're trying to pass the wrong kind of method to it.

If you want the RelayCommand to support Command Parameters, you should use RelayCommand<T> where T can be any type of parameter. In your situation it would be RelayCommand<String> which would accept a method with void(string) signature. (and therefor would also be strongly typed and won't use the ugly object)

Erubescence answered 14/3, 2011 at 13:14 Comment(0)
I
2

Another way to declare relay commands, will help to reduce your code

public RelayCommand ChartCommand
{
    set
    {
        RelayCommand<string> chartCommand = 
            new RelayCommand<string>(e => ExecuteChartCommand(e));               
    }
}

public void ExecuteChartCommand(string vendor)
{

}
I answered 12/11, 2012 at 11:26 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.