Hans Karlsen (talk | contribs) No edit summary |
Hans Karlsen (talk | contribs) No edit summary |
||
Line 34: | Line 34: | ||
<input asp-for="ThisAsExternalId" hidden /> | <input asp-for="ThisAsExternalId" hidden /> | ||
<input asp-for="ViewModelClass.ViewModel.Name" hidden/> | <input asp-for="ViewModelClass.ViewModel.Name" hidden/> | ||
To use Runtime generated Razor files from ViewModel do like this - see comments on | To use Runtime generated Razor files from ViewModel do like this - see comments on why each row is added and choose wisely: | ||
<pre> | <pre> | ||
public class Startup | public class Startup |
Revision as of 17:07, 11 October 2021
The Turnkey WebApplication uses MVC for index and login pages - it defaults to angularjs for all other pages. To get MVC on other pages you must set tagged value MVC=true on ViewModel.
MVC works differently from Angular in a number of ways - the main differences are these:
- Grid-row-clicks, in MVC select of row is done if there are zero or many actions, but if there is 1 action (defined in ViewModel) this action is executed on row click
- MVC never shows a popup menu of multiple actions as angular does
How to build MVC apps with MDrivenFramework
MVC_Generated_ViewModel_UI_in_MDrivenFramework
Comboboxes_in_MVC_from_model_driven_ViewModel
Getting_started_template_for_MDriven_MVC
New MVC Notes Autumn 2021
New nuget packages for .net5 and .netStandard are published on nuget and named MDriven.*
To get a package into a EcoSpace by code add an attribute to EcoSpace like [EcoSpacePackage(typeof(Package1Package))]
To get binding a codegen ViewModel to work go like this:
public IActionResult View([ModelBinder(typeof(VMClassBinder))] SampleViewModel value) { return View("View"); }
To supress the bogus validation done on VMClass go like this:
var mvc = services.AddMvc(options => { options.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(VMClass))); }); // to avoid validation of the complete world by following VMClass refs
To enable your page to roundtrip truly stateless we need to know the ViewModel name and Root object id on postback. Add these hidden fields in your form:
<input asp-for="ThisAsExternalId" hidden /> <input asp-for="ViewModelClass.ViewModel.Name" hidden/>
To use Runtime generated Razor files from ViewModel do like this - see comments on why each row is added and choose wisely:
public class Startup { public Startup(IWebHostEnvironment env, IConfiguration configuration) //added to inject the IWebHostEnvironment, needed for files { _HostingEnvironment = env; Configuration = configuration; } private IWebHostEnvironment _HostingEnvironment; public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddControllersWithViews(); services.AddMemoryCache(); // to hold shelved ecospaces var mvc = services.AddMvc(options => { options.ModelMetadataDetailsProviders.Add(new SuppressChildValidationMetadataProvider(typeof(VMClass))); // to avoid validation of the complete world by following VMClass refs }); mvc.AddSessionStateTempDataProvider(); services.AddSession(); // To hold selection etc during roundtrip services.Configure<MvcRazorRuntimeCompilationOptions>(options => { // Needed to generate Razor for ViewModels options.FileProviders.Clear(); options.FileProviders.Add(new MDrivenMVCCoreFileProvider(this._HostingEnvironment.ContentRootFileProvider, Directory.GetCurrentDirectory())); }); services.AddRazorPages().AddRazorRuntimeCompilation(); //without AddRazorRuntimeCompilation our fileProvider is not called; } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } app.UseHttpsRedirection(); app.UseStaticFiles(); app.UseSession(); // to hold vm vars during MVC roundtrip app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{id?}"); }); } }