feat: Moves employee views to their own controller, updates css, and employee table view.
This commit is contained in:
@@ -7,9 +7,8 @@ struct ViewController: RouteCollection {
|
||||
private let api = ApiController()
|
||||
|
||||
func boot(routes: any RoutesBuilder) throws {
|
||||
let protected = routes.grouped(User.credentialsAuthenticator(), User.redirectMiddleware(path: "login"))
|
||||
let protected = routes.protected
|
||||
let login = routes.grouped("login")
|
||||
let employees = protected.grouped("employees")
|
||||
|
||||
// MARK: - Non-protected routes.
|
||||
|
||||
@@ -23,12 +22,7 @@ struct ViewController: RouteCollection {
|
||||
protected.get("home", use: home(req:))
|
||||
protected.get("users", use: users(req:))
|
||||
|
||||
employees.get(use: employees(req:))
|
||||
employees.post(use: postEmployeeForm(req:))
|
||||
employees.group(":employeeID") {
|
||||
$0.delete(use: deleteEmployee(req:))
|
||||
$0.post("toggle-active", use: toggleActiveEmployee(req:))
|
||||
}
|
||||
try routes.register(collection: EmployeeViewController())
|
||||
}
|
||||
|
||||
@Sendable
|
||||
@@ -66,6 +60,8 @@ struct ViewController: RouteCollection {
|
||||
return try await req.view.render("login")
|
||||
}
|
||||
|
||||
// TODO: Add route parameters for active route / tab.
|
||||
|
||||
@Sendable
|
||||
func home(req: Request) async throws -> View {
|
||||
try await req.view.render("home")
|
||||
@@ -77,50 +73,9 @@ struct ViewController: RouteCollection {
|
||||
return try await req.view.render("users", ["users": users])
|
||||
}
|
||||
|
||||
@Sendable
|
||||
func employees(req: Request) async throws -> View {
|
||||
let employees = try await api.getSortedEmployees(req: req)
|
||||
return try await req.view.render("employees", ["employees": employees])
|
||||
}
|
||||
|
||||
@Sendable
|
||||
func postEmployeeForm(req: Request) async throws -> View {
|
||||
_ = try await api.createEmployee(req: req)
|
||||
let employees = try await api.getSortedEmployees(req: req)
|
||||
return try await req.view.render("employee-table", ["employees": employees])
|
||||
}
|
||||
|
||||
@Sendable
|
||||
func toggleActiveEmployee(req: Request) async throws -> View {
|
||||
guard let employee = try await Employee.find(req.parameters.get("employeeID"), on: req.db) else {
|
||||
throw Abort(.notFound)
|
||||
}
|
||||
employee.active.toggle()
|
||||
try await employee.save(on: req.db)
|
||||
let employees = try await api.getSortedEmployees(req: req)
|
||||
return try await req.view.render("employee-table", ["employees": employees])
|
||||
}
|
||||
|
||||
@Sendable
|
||||
func deleteEmployee(req: Request) async throws -> View {
|
||||
_ = try await api.deleteEmployee(req: req)
|
||||
let employees = try await api.getSortedEmployees(req: req)
|
||||
return try await req.view.render("employee-table", ["employees": employees])
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private struct UserForm: Content {
|
||||
let username: String
|
||||
let password: String
|
||||
}
|
||||
|
||||
private extension ApiController {
|
||||
|
||||
func getSortedEmployees(req: Request) async throws -> [Employee.DTO] {
|
||||
var employees = try await employeesIndex(req: req)
|
||||
employees.sort { ($0.active ?? false) && !($1.active ?? false) }
|
||||
employees.sort { ($0.lastName ?? "") < ($1.lastName ?? "") }
|
||||
return employees
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user