Comboboxes in MVC from model driven ViewModel
No edit summary
No edit summary
Line 6: Line 6:


When creating the viewmodel go like this (Look at the 2 last lines in the Green ViewModelClass and at the blue):
When creating the viewmodel go like this (Look at the 2 last lines in the Green ViewModelClass and at the blue):
[[File:Comboboxes - 1.png|border|frameless|354x354px]]


This is automated for you if you want by right clicking:
This is automated for you if you want by right clicking:
[[File:Comboboxes - 2.png|border|frameless|357x357px]]


Modlr knows that “Example1” is a perfect candidate for a Combobox since it is a single link.
Modlr knows that “Example1” is a perfect candidate for a Combobox since it is a single link.


You get this:
You get this:
[[File:Comboboxes - 3.png|border|frameless|362x362px]]


Modlr suggests Example1.allinstances to be the pick list, but you are free to change it. Maybe you want to add a “->orderby(e|e.attribute1)” there.
Modlr suggests Example1.allinstances to be the pick list, but you are free to change it. Maybe you want to add a “->orderby(e|e.attribute1)” there.


To get the whole MVC roundtrip to work – we need to add an identity column to the PickListPresentation class.
To get the whole MVC roundtrip to work – we need to add an identity column to the PickListPresentation class.
[[File:Comboboxes - 4.png|border|frameless|300x300px]]


I make sure CodeGen is checked and then generate code:
I make sure CodeGen is checked and then generate code:
[[File:Comboboxes - 5.png|border|frameless|448x448px]]


Looking at the generated code for the ViewModel VMExample2 we see this new thing:
Looking at the generated code for the ViewModel VMExample2 we see this new thing:
[[File:Comboboxes - 6.png|border|frameless|300x300px]]


Notice that modlr  did not only add code for Example1, it also added code for Example1_AsExternalId… And this is important for MVC.
Notice that modlr  did not only add code for Example1, it also added code for Example1_AsExternalId… And this is important for MVC.
Line 41: Line 53:


And I get this:
And I get this:
[[File:Comboboxes - 7.png|border|frameless|244x244px]]


Then I change in the combo and press save:
Then I change in the combo and press save:
[[File:Comboboxes - 8.png|border|frameless|244x244px]]


The save method needs to do nothing special to make this happen:
The save method needs to do nothing special to make this happen:

Revision as of 15:10, 6 November 2018

To get everything to work as in the article you need the latest build (written 131108)

Combobox, picklist or dropdown list – many names for the same thing.

The combobox is perfect when setting references between objects – if the number of items to pick from is not too large.

When creating the viewmodel go like this (Look at the 2 last lines in the Green ViewModelClass and at the blue):

Comboboxes - 1.png

This is automated for you if you want by right clicking:

Comboboxes - 2.png

Modlr knows that “Example1” is a perfect candidate for a Combobox since it is a single link.

You get this:

Comboboxes - 3.png

Modlr suggests Example1.allinstances to be the pick list, but you are free to change it. Maybe you want to add a “->orderby(e|e.attribute1)” there.

To get the whole MVC roundtrip to work – we need to add an identity column to the PickListPresentation class.

Comboboxes - 4.png

I make sure CodeGen is checked and then generate code:

Comboboxes - 5.png

Looking at the generated code for the ViewModel VMExample2 we see this new thing:

Comboboxes - 6.png

Notice that modlr  did not only add code for Example1, it also added code for Example1_AsExternalId… And this is important for MVC.

In the View I enter this:

    <div class="display-field">
      @Html.DropDownListFor(x => x.Example1_AsExternalId, 
        new SelectList(Model.Example1_PickList , //The list
                       "Identity",               // What attribute to pick
                       "Presentation",           // what to present
                       Model.Example1_AsExternalId)) // what to set on pick
    </div>
    <div class="display-field">
            @Html.EditorFor(model => model.OwnedBy)    // Added this just for info   
    </div>

And I get this:

Comboboxes - 7.png

Then I change in the combo and press save:

Comboboxes - 8.png

The save method needs to do nothing special to make this happen:

        [HttpPost]
        public ActionResult Details(string Identity, VMExample2 offlinevm)
        {
          Example2 e2 = EcoSpace.ExternalIds.ObjectForId(Identity).AsObject as Example2;
          try
          {
            VMExample2 onlinevm=VMExample2.Create(EcoSpace, e2);
            ViewModelHelper.ApplyValues(offlinevm, onlinevm, null);
            Commit();
            return View("Details", onlinevm);
          }
          catch
          {
            return View("Details", offlinevm);
          }
        }

This page was edited more than 11 months ago on 02/10/2024. What links here