mirror of
https://github.com/claunia/marechai.git
synced 2025-12-16 19:14:25 +00:00
Implement create admin page for screens by machine.
This commit is contained in:
@@ -52,8 +52,14 @@ namespace cicm_web.Areas.Admin.Controllers
|
|||||||
// GET: ScreensByMachine/Create
|
// GET: ScreensByMachine/Create
|
||||||
public IActionResult Create()
|
public IActionResult Create()
|
||||||
{
|
{
|
||||||
ViewData["MachineId"] = new SelectList(_context.Machines, "Id", "Name");
|
ViewData["MachineId"] =
|
||||||
ViewData["ScreenId"] = new SelectList(_context.Screens, "Id", "Type");
|
new
|
||||||
|
SelectList(_context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).Select(m => new {m.Id, Name = $"{m.Company.Name} {m.Name}"}),
|
||||||
|
"Id", "Name");
|
||||||
|
ViewData["ScreenId"] =
|
||||||
|
new
|
||||||
|
SelectList(_context.Screens.Select(s => new {s.Id, Name = s.NativeResolution != null ? $"{s.Diagonal}\" {s.Type} with {s.NativeResolution}" : $"{s.Diagonal}\" {s.Type}"}).OrderBy(s => s.Name),
|
||||||
|
"Id", "Name");
|
||||||
return View();
|
return View();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -71,8 +77,14 @@ namespace cicm_web.Areas.Admin.Controllers
|
|||||||
return RedirectToAction(nameof(Index));
|
return RedirectToAction(nameof(Index));
|
||||||
}
|
}
|
||||||
|
|
||||||
ViewData["MachineId"] = new SelectList(_context.Machines, "Id", "Name", screensByMachine.MachineId);
|
ViewData["MachineId"] =
|
||||||
ViewData["ScreenId"] = new SelectList(_context.Screens, "Id", "Type", screensByMachine.ScreenId);
|
new
|
||||||
|
SelectList(_context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).Select(m => new {m.Id, Name = $"{m.Company.Name} {m.Name}"}),
|
||||||
|
"Id", "Name", screensByMachine.MachineId);
|
||||||
|
ViewData["ScreenId"] =
|
||||||
|
new
|
||||||
|
SelectList(_context.Screens.Select(s => new {s.Id, Name = s.NativeResolution != null ? $"{s.Diagonal}\" {s.Type} with {s.NativeResolution}" : $"{s.Diagonal}\" {s.Type}"}).OrderBy(s => s.Name),
|
||||||
|
"Id", "Name", screensByMachine.ScreenId);
|
||||||
return View(screensByMachine);
|
return View(screensByMachine);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -84,8 +96,14 @@ namespace cicm_web.Areas.Admin.Controllers
|
|||||||
ScreensByMachine screensByMachine = await _context.ScreensByMachine.FindAsync(id);
|
ScreensByMachine screensByMachine = await _context.ScreensByMachine.FindAsync(id);
|
||||||
if(screensByMachine == null) return NotFound();
|
if(screensByMachine == null) return NotFound();
|
||||||
|
|
||||||
ViewData["MachineId"] = new SelectList(_context.Machines, "Id", "Name", screensByMachine.MachineId);
|
ViewData["MachineId"] =
|
||||||
ViewData["ScreenId"] = new SelectList(_context.Screens, "Id", "Type", screensByMachine.ScreenId);
|
new
|
||||||
|
SelectList(_context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).Select(m => new {m.Id, Name = $"{m.Company.Name} {m.Name}"}),
|
||||||
|
"Id", "Name", screensByMachine.MachineId);
|
||||||
|
ViewData["ScreenId"] =
|
||||||
|
new
|
||||||
|
SelectList(_context.Screens.Select(s => new {s.Id, Name = s.NativeResolution != null ? $"{s.Diagonal}\" {s.Type} with {s.NativeResolution}" : $"{s.Diagonal}\" {s.Type}"}).OrderBy(s => s.Name),
|
||||||
|
"Id", "Name", screensByMachine.ScreenId);
|
||||||
return View(screensByMachine);
|
return View(screensByMachine);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -116,8 +134,14 @@ namespace cicm_web.Areas.Admin.Controllers
|
|||||||
return RedirectToAction(nameof(Index));
|
return RedirectToAction(nameof(Index));
|
||||||
}
|
}
|
||||||
|
|
||||||
ViewData["MachineId"] = new SelectList(_context.Machines, "Id", "Name", screensByMachine.MachineId);
|
ViewData["MachineId"] =
|
||||||
ViewData["ScreenId"] = new SelectList(_context.Screens, "Id", "Type", screensByMachine.ScreenId);
|
new
|
||||||
|
SelectList(_context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).Select(m => new {m.Id, Name = $"{m.Company.Name} {m.Name}"}),
|
||||||
|
"Id", "Name", screensByMachine.MachineId);
|
||||||
|
ViewData["ScreenId"] =
|
||||||
|
new
|
||||||
|
SelectList(_context.Screens.Select(s => new {s.Id, Name = s.NativeResolution != null ? $"{s.Diagonal}\" {s.Type} with {s.NativeResolution}" : $"{s.Diagonal}\" {s.Type}"}).OrderBy(s => s.Name),
|
||||||
|
"Id", "Name", screensByMachine.ScreenId);
|
||||||
return View(screensByMachine);
|
return View(screensByMachine);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -150,5 +174,14 @@ namespace cicm_web.Areas.Admin.Controllers
|
|||||||
{
|
{
|
||||||
return _context.ScreensByMachine.Any(e => e.Id == id);
|
return _context.ScreensByMachine.Any(e => e.Id == id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[AcceptVerbs("Get", "Post")]
|
||||||
|
public async Task<IActionResult> VerifyUnique(int screenId, int machineId)
|
||||||
|
{
|
||||||
|
return await _context.ScreensByMachine.FirstOrDefaultAsync(i => i.ScreenId == screenId &&
|
||||||
|
i.MachineId == machineId) is null
|
||||||
|
? Json(true)
|
||||||
|
: Json("The selected machine already has the selected screen.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
<h1>Create</h1>
|
<h1>Create</h1>
|
||||||
|
|
||||||
<h4>ScreensByMachine</h4>
|
<h4>Screens by machine</h4>
|
||||||
<hr />
|
<hr />
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
@@ -15,36 +15,42 @@
|
|||||||
class="text-danger">
|
class="text-danger">
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label asp-for="ScreenId"
|
<label asp-for="Screen"
|
||||||
class="control-label">
|
class="control-label">
|
||||||
</label>
|
</label>
|
||||||
<select asp-for="ScreenId"
|
<select asp-for="ScreenId"
|
||||||
class="form-control"
|
class="form-control"
|
||||||
asp-items="ViewBag.ScreenId">
|
asp-items="ViewBag.ScreenId">
|
||||||
</select>
|
</select>
|
||||||
|
<span asp-validation-for="ScreenId"
|
||||||
|
class="text-danger">
|
||||||
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label asp-for="MachineId"
|
<label asp-for="Machine"
|
||||||
class="control-label">
|
class="control-label">
|
||||||
</label>
|
</label>
|
||||||
<select asp-for="MachineId"
|
<select asp-for="MachineId"
|
||||||
class="form-control"
|
class="form-control"
|
||||||
asp-items="ViewBag.MachineId">
|
asp-items="ViewBag.MachineId">
|
||||||
</select>
|
</select>
|
||||||
|
<span asp-validation-for="MachineId"
|
||||||
|
class="text-danger">
|
||||||
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<input class="btn btn-primary"
|
<input class="btn btn-primary"
|
||||||
type="submit"
|
type="submit"
|
||||||
value="Create" />
|
value="Create" />
|
||||||
|
<a asp-action="Index"
|
||||||
|
class="btn btn-secondary">
|
||||||
|
Back to List
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div>
|
|
||||||
<a asp-action="Index">Back to List</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
@section Scripts {
|
@section Scripts {
|
||||||
@{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); }
|
@{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); }
|
||||||
}
|
}
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk.Web">
|
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>netcoreapp2.2</TargetFramework>
|
<TargetFramework>netcoreapp2.2</TargetFramework>
|
||||||
<Version>3.0.99.744</Version>
|
<Version>3.0.99.747</Version>
|
||||||
<Company>Canary Islands Computer Museum</Company>
|
<Company>Canary Islands Computer Museum</Company>
|
||||||
<Copyright>Copyright © 2003-2018 Natalia Portillo</Copyright>
|
<Copyright>Copyright © 2003-2018 Natalia Portillo</Copyright>
|
||||||
<Product>Canary Islands Computer Museum Website</Product>
|
<Product>Canary Islands Computer Museum Website</Product>
|
||||||
|
|||||||
Reference in New Issue
Block a user