feat: Refactoring route declarations.
This commit is contained in:
@@ -4,21 +4,38 @@ import Fluent
|
||||
import SharedModels
|
||||
|
||||
extension HTMLAttribute.hx {
|
||||
static func get(route: RouteKey) -> HTMLAttribute {
|
||||
get(route.url)
|
||||
static func get(route: SharedModels.ViewRoute) -> HTMLAttribute {
|
||||
get(SharedModels.ViewRoute.router.path(for: route))
|
||||
}
|
||||
|
||||
static func post(route: RouteKey) -> HTMLAttribute {
|
||||
post(route.url)
|
||||
static func post(route: SharedModels.ViewRoute) -> HTMLAttribute {
|
||||
post(SharedModels.ViewRoute.router.path(for: route))
|
||||
}
|
||||
|
||||
static func put(route: RouteKey) -> HTMLAttribute {
|
||||
put(route.url)
|
||||
static func put(route: SharedModels.ViewRoute) -> HTMLAttribute {
|
||||
put(SharedModels.ViewRoute.router.path(for: route))
|
||||
}
|
||||
|
||||
static func delete(route: RouteKey) -> HTMLAttribute {
|
||||
delete(route.url)
|
||||
static func delete(route: SharedModels.ViewRoute) -> HTMLAttribute {
|
||||
delete(SharedModels.ViewRoute.router.path(for: route))
|
||||
}
|
||||
|
||||
// static func get(route: SharedModels.ApiRoute) -> HTMLAttribute {
|
||||
// get(route: .shared(route))
|
||||
// }
|
||||
//
|
||||
// static func post(route: SharedModels.ApiRoute) -> HTMLAttribute {
|
||||
// post(SharedModels.ApiRoute.router.path(for: route))
|
||||
// }
|
||||
//
|
||||
// static func put(route: SharedModels.ApiRoute) -> HTMLAttribute {
|
||||
// put(SharedModels.ApiRoute.router.path(for: route))
|
||||
// }
|
||||
//
|
||||
// static func delete(route: SharedModels.ApiRoute) -> HTMLAttribute {
|
||||
// delete(SharedModels.ApiRoute.router.path(for: route))
|
||||
// }
|
||||
|
||||
}
|
||||
|
||||
extension HTMLAttribute.hx {
|
||||
@@ -34,6 +51,7 @@ extension HTMLAttribute where Tag: HTMLTrait.Attributes.Global {
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: Remove.
|
||||
enum RouteKey {
|
||||
case employees(EmployeeRoute? = nil)
|
||||
case purchaseOrders(PurchaseOrderRoute? = nil)
|
||||
@@ -73,8 +91,8 @@ enum RouteKey {
|
||||
enum PurchaseOrderRoute {
|
||||
case create
|
||||
case nextPage(PageMetadata)
|
||||
case search(SearchQuery? = nil)
|
||||
|
||||
// case search(SearchQuery? = nil)
|
||||
//
|
||||
var path: String {
|
||||
switch self {
|
||||
case .create:
|
||||
@@ -82,25 +100,24 @@ enum RouteKey {
|
||||
|
||||
case let .nextPage(currentPage):
|
||||
return "next?page=\(currentPage.page + 1)&limit\(currentPage.per)"
|
||||
|
||||
case let .search(query):
|
||||
guard let query else { return "search" }
|
||||
return "search?\(query.query)"
|
||||
// case let .search(query):
|
||||
// guard let query else { return "search" }
|
||||
// return "search?\(query.query)"
|
||||
}
|
||||
}
|
||||
|
||||
enum SearchQuery {
|
||||
case context(PurchaseOrderSearchContext, table: Bool? = nil)
|
||||
|
||||
var query: String {
|
||||
switch self {
|
||||
case let .context(context, table):
|
||||
let query = "context=\(context.rawValue)"
|
||||
guard let table else { return query }
|
||||
return "\(query)&table=\(table)"
|
||||
}
|
||||
}
|
||||
}
|
||||
// enum SearchQuery {
|
||||
// case context(PurchaseOrderSearchContext, table: Bool? = nil)
|
||||
//
|
||||
// var query: String {
|
||||
// switch self {
|
||||
// case let .context(context, table):
|
||||
// let query = "context=\(context.rawValue)"
|
||||
// guard let table else { return query }
|
||||
// return "\(query)&table=\(table)"
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
enum UserRoute {
|
||||
|
||||
Reference in New Issue
Block a user