routing
This commit is contained in:
@@ -24,18 +24,33 @@ func MenuHandlerRoutes(r fiber.Router) fiber.Router {
|
|||||||
handler := NewMenuHandler()
|
handler := NewMenuHandler()
|
||||||
|
|
||||||
r.Get("/get-menu", handler.GetMenu)
|
r.Get("/get-menu", handler.GetMenu)
|
||||||
|
r.Get("/get-routes", handler.GetRouting)
|
||||||
|
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *MenuHandler) GetMenu(c fiber.Ctx) error {
|
func (h *MenuHandler) GetMenu(c fiber.Ctx) error {
|
||||||
id_lang, ok := c.Locals("langID").(uint)
|
lang_id, ok := c.Locals("langID").(uint)
|
||||||
if !ok {
|
if !ok {
|
||||||
return c.Status(responseErrors.GetErrorStatus(responseErrors.ErrBadAttribute)).
|
return c.Status(responseErrors.GetErrorStatus(responseErrors.ErrBadAttribute)).
|
||||||
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, responseErrors.ErrBadAttribute)))
|
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, responseErrors.ErrBadAttribute)))
|
||||||
}
|
}
|
||||||
|
menu, err := h.menuService.GetMenu(lang_id)
|
||||||
menu, err := h.menuService.GetMenu(id_lang)
|
if err != nil {
|
||||||
|
return c.Status(responseErrors.GetErrorStatus(err)).
|
||||||
|
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, err)))
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.JSON(response.Make(&menu, 0, i18n.T_(c, response.Message_OK)))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *MenuHandler) GetRouting(c fiber.Ctx) error {
|
||||||
|
lang_id, ok := c.Locals("langID").(uint)
|
||||||
|
if !ok {
|
||||||
|
return c.Status(responseErrors.GetErrorStatus(responseErrors.ErrBadAttribute)).
|
||||||
|
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, responseErrors.ErrBadAttribute)))
|
||||||
|
}
|
||||||
|
menu, err := h.menuService.GetRoutes(lang_id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return c.Status(responseErrors.GetErrorStatus(err)).
|
return c.Status(responseErrors.GetErrorStatus(err)).
|
||||||
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, err)))
|
JSON(response.Make(nullable.GetNil(""), 0, responseErrors.GetErrorCode(c, err)))
|
||||||
|
|||||||
@@ -110,6 +110,10 @@ func (s *Server) Setup() error {
|
|||||||
meiliSearch := s.restricted.Group("/meili-search")
|
meiliSearch := s.restricted.Group("/meili-search")
|
||||||
restricted.MeiliSearchHandlerRoutes(meiliSearch)
|
restricted.MeiliSearchHandlerRoutes(meiliSearch)
|
||||||
|
|
||||||
|
s.api.All("*", func(c fiber.Ctx) error {
|
||||||
|
return c.SendStatus(fiber.StatusNotFound)
|
||||||
|
})
|
||||||
|
|
||||||
// // Restricted routes example
|
// // Restricted routes example
|
||||||
// restricted := s.api.Group("/restricted")
|
// restricted := s.api.Group("/restricted")
|
||||||
// restricted.Use(middleware.AuthMiddleware())
|
// restricted.Use(middleware.AuthMiddleware())
|
||||||
|
|||||||
21
app/model/routing.go
Normal file
21
app/model/routing.go
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package model
|
||||||
|
|
||||||
|
type Route struct {
|
||||||
|
ID uint `gorm:"primaryKey;autoIncrement"`
|
||||||
|
Name string `gorm:"type:varchar(255);not null;unique"`
|
||||||
|
Path *string `gorm:"type:varchar(255);default:null"`
|
||||||
|
Component string `gorm:"type:varchar(255);not null;comment:path to component file"`
|
||||||
|
Layout *string `gorm:"type:varchar(50);default:'default';comment:'default | empty'"`
|
||||||
|
Meta *string `gorm:"type:longtext;default:'{}'"`
|
||||||
|
IsActive *bool `gorm:"type:tinyint;default:1"`
|
||||||
|
SortOrder *int `gorm:"type:int;default:0"`
|
||||||
|
|
||||||
|
ParentID *uint `gorm:"index"`
|
||||||
|
Parent *Route `gorm:"constraint:OnUpdate:RESTRICT,OnDelete:SET NULL;foreignKey:ParentID"`
|
||||||
|
|
||||||
|
Children []Route `gorm:"foreignKey:ParentID"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (Route) TableName() string {
|
||||||
|
return "b2b_routes"
|
||||||
|
}
|
||||||
@@ -30,22 +30,12 @@ func (repo *CategoriesRepo) GetAllCategories(id_lang uint) ([]model.ScannedCateg
|
|||||||
ps_category.is_root_category AS is_root_category,
|
ps_category.is_root_category AS is_root_category,
|
||||||
ps_category_lang.link_rewrite AS link_rewrite,
|
ps_category_lang.link_rewrite AS link_rewrite,
|
||||||
ps_lang.iso_code AS iso_code
|
ps_lang.iso_code AS iso_code
|
||||||
`).
|
FROM ps_category
|
||||||
Joins(`
|
LEFT JOIN ps_category_lang ON ps_category_lang.id_category = ps_category.id_category AND ps_category_lang.id_shop = ? AND ps_category_lang.id_lang = ?
|
||||||
LEFT JOIN ps_category_lang
|
LEFT JOIN ps_category_shop ON ps_category_shop.id_category = ps_category.id_category AND ps_category_shop.id_shop = ?
|
||||||
ON ps_category_lang.id_category = ps_category.id_category
|
JOIN ps_lang ON ps_lang.id_lang = ps_category_lang.id_lang
|
||||||
AND ps_category_lang.id_shop = ?
|
`,
|
||||||
AND ps_category_lang.id_lang = ?
|
constdata.SHOP_ID, id_lang, constdata.SHOP_ID).
|
||||||
`, constdata.SHOP_ID, id_lang).
|
|
||||||
Joins(`
|
|
||||||
LEFT JOIN ps_category_shop
|
|
||||||
ON ps_category_shop.id_category = ps_category.id_category
|
|
||||||
AND ps_category_shop.id_shop = ?
|
|
||||||
`, constdata.SHOP_ID).
|
|
||||||
Joins(`
|
|
||||||
JOIN ps_lang
|
|
||||||
ON ps_lang.id_lang = ps_category_lang.id_lang
|
|
||||||
`).
|
|
||||||
Scan(&allCategories).Error
|
Scan(&allCategories).Error
|
||||||
|
|
||||||
return allCategories, err
|
return allCategories, err
|
||||||
|
|||||||
25
app/repos/routesRepo/routesRepo.go
Normal file
25
app/repos/routesRepo/routesRepo.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package routesrepo
|
||||||
|
|
||||||
|
import (
|
||||||
|
"git.ma-al.com/goc_daniel/b2b/app/db"
|
||||||
|
"git.ma-al.com/goc_daniel/b2b/app/model"
|
||||||
|
)
|
||||||
|
|
||||||
|
type UIRoutesRepo interface {
|
||||||
|
GetRoutes(langId uint) ([]model.Route, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
type RoutesRepo struct{}
|
||||||
|
|
||||||
|
func New() UIRoutesRepo {
|
||||||
|
return &RoutesRepo{}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *RoutesRepo) GetRoutes(langId uint) ([]model.Route, error) {
|
||||||
|
routes := []model.Route{}
|
||||||
|
err := db.DB.Find(&routes).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return routes, nil
|
||||||
|
}
|
||||||
@@ -5,23 +5,26 @@ import (
|
|||||||
|
|
||||||
"git.ma-al.com/goc_daniel/b2b/app/model"
|
"git.ma-al.com/goc_daniel/b2b/app/model"
|
||||||
"git.ma-al.com/goc_daniel/b2b/app/repos/categoriesRepo"
|
"git.ma-al.com/goc_daniel/b2b/app/repos/categoriesRepo"
|
||||||
|
routesRepo "git.ma-al.com/goc_daniel/b2b/app/repos/routesRepo"
|
||||||
"git.ma-al.com/goc_daniel/b2b/app/utils/responseErrors"
|
"git.ma-al.com/goc_daniel/b2b/app/utils/responseErrors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type MenuService struct {
|
type MenuService struct {
|
||||||
categoriesRepo categoriesRepo.UICategoriesRepo
|
categoriesRepo categoriesRepo.UICategoriesRepo
|
||||||
|
routesRepo routesRepo.UIRoutesRepo
|
||||||
}
|
}
|
||||||
|
|
||||||
func New() *MenuService {
|
func New() *MenuService {
|
||||||
return &MenuService{
|
return &MenuService{
|
||||||
categoriesRepo: categoriesRepo.New(),
|
categoriesRepo: categoriesRepo.New(),
|
||||||
|
routesRepo: routesRepo.New(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *MenuService) GetMenu(id_lang uint) (model.Category, error) {
|
func (s *MenuService) GetMenu(id_lang uint) (*model.Category, error) {
|
||||||
all_categories, err := s.categoriesRepo.GetAllCategories(id_lang)
|
all_categories, err := s.categoriesRepo.GetAllCategories(id_lang)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return model.Category{}, err
|
return &model.Category{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// find the root
|
// find the root
|
||||||
@@ -35,7 +38,7 @@ func (s *MenuService) GetMenu(id_lang uint) (model.Category, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if !root_found {
|
if !root_found {
|
||||||
return model.Category{}, responseErrors.ErrNoRootFound
|
return &model.Category{}, responseErrors.ErrNoRootFound
|
||||||
}
|
}
|
||||||
|
|
||||||
// now create the children and reorder them according to position
|
// now create the children and reorder them according to position
|
||||||
@@ -57,7 +60,7 @@ func (s *MenuService) GetMenu(id_lang uint) (model.Category, error) {
|
|||||||
// finally, create the tree
|
// finally, create the tree
|
||||||
tree := s.createTree(root_index, &all_categories, &children_indices)
|
tree := s.createTree(root_index, &all_categories, &children_indices)
|
||||||
|
|
||||||
return tree, nil
|
return &tree, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *MenuService) createTree(index int, all_categories *([]model.ScannedCategory), children_indices *(map[int][]ChildWithPosition)) model.Category {
|
func (s *MenuService) createTree(index int, all_categories *([]model.ScannedCategory), children_indices *(map[int][]ChildWithPosition)) model.Category {
|
||||||
@@ -70,6 +73,10 @@ func (s *MenuService) createTree(index int, all_categories *([]model.ScannedCate
|
|||||||
return node
|
return node
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *MenuService) GetRoutes(id_lang uint) ([]model.Route, error) {
|
||||||
|
return s.routesRepo.GetRoutes(id_lang)
|
||||||
|
}
|
||||||
|
|
||||||
func (s *MenuService) scannedToNormalCategory(scanned model.ScannedCategory) model.Category {
|
func (s *MenuService) scannedToNormalCategory(scanned model.ScannedCategory) model.Category {
|
||||||
var normal model.Category
|
var normal model.Category
|
||||||
// normal.Active = scanned.Active
|
// normal.Active = scanned.Active
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import { currentLang, langs } from './langs'
|
|||||||
import { getSettings } from './settings'
|
import { getSettings } from './settings'
|
||||||
import { useAuthStore } from '@/stores/auth'
|
import { useAuthStore } from '@/stores/auth'
|
||||||
import Default from '@/layouts/default.vue'
|
import Default from '@/layouts/default.vue'
|
||||||
|
import { getMenu } from './menu'
|
||||||
|
|
||||||
|
|
||||||
function isAuthenticated(): boolean {
|
function isAuthenticated(): boolean {
|
||||||
|
|||||||
@@ -1,7 +1,16 @@
|
|||||||
import { useFetchJson } from "@/composable/useFetchJson";
|
import { useFetchJson } from "@/composable/useFetchJson";
|
||||||
|
import type { MenuItem, Route } from "@/types/menu";
|
||||||
|
|
||||||
export const getMenu = async () => {
|
export const getMenu = async () => {
|
||||||
const resp = await useFetchJson('/api/v1/restricted/menu/get-menu');
|
const resp = await useFetchJson<MenuItem>('/api/v1/restricted/menu/get-menu');
|
||||||
|
|
||||||
|
return resp.items.children
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export const getRoutes = async () => {
|
||||||
|
const resp = await useFetchJson<Route[]>('/api/v1/restricted/menu/get-routes');
|
||||||
|
|
||||||
return resp.items
|
return resp.items
|
||||||
|
|
||||||
|
|||||||
26
bo/src/types/menu.d.ts
vendored
Normal file
26
bo/src/types/menu.d.ts
vendored
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
export interface MenuItem {
|
||||||
|
category_id: number
|
||||||
|
label: string
|
||||||
|
params: Params
|
||||||
|
children: MenuItem[]
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Params {
|
||||||
|
category_id?: number
|
||||||
|
link_rewrite?: string
|
||||||
|
locale?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Route {
|
||||||
|
ID: number
|
||||||
|
Name: string
|
||||||
|
Path: string
|
||||||
|
Component: string
|
||||||
|
Layout: string
|
||||||
|
Meta: string
|
||||||
|
IsActive: boolean
|
||||||
|
SortOrder: number
|
||||||
|
ParentID: any
|
||||||
|
Parent: any
|
||||||
|
Children: any
|
||||||
|
}
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
-- +goose Up
|
-- +goose Up
|
||||||
-- create routes table
|
-- create routes table
|
||||||
CREATE TABLE IF NOT EXISTS b2b_tracker_routes (
|
CREATE TABLE IF NOT EXISTS b2b_routes (
|
||||||
id INT AUTO_INCREMENT PRIMARY KEY,
|
id INT AUTO_INCREMENT PRIMARY KEY,
|
||||||
name VARCHAR(255) NOT NULL UNIQUE,
|
name VARCHAR(255) NOT NULL UNIQUE,
|
||||||
path VARCHAR(255) NULL,
|
path VARCHAR(255) NULL,
|
||||||
@@ -13,11 +13,11 @@ CREATE TABLE IF NOT EXISTS b2b_tracker_routes (
|
|||||||
|
|
||||||
CONSTRAINT fk_parent
|
CONSTRAINT fk_parent
|
||||||
FOREIGN KEY (parent_id)
|
FOREIGN KEY (parent_id)
|
||||||
REFERENCES b2b_tracker_routes(id)
|
REFERENCES b2b_routes(id)
|
||||||
ON DELETE SET NULL
|
ON DELETE SET NULL
|
||||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
|
||||||
|
|
||||||
INSERT IGNORE INTO b2b_tracker_routes
|
INSERT IGNORE INTO b2b_routes
|
||||||
(name, path, component, layout, meta, is_active, sort_order, parent_id)
|
(name, path, component, layout, meta, is_active, sort_order, parent_id)
|
||||||
VALUES
|
VALUES
|
||||||
('root', '', '', 'default', '{"trans": "route.root"}', 0, 0, 0),
|
('root', '', '', 'default', '{"trans": "route.root"}', 0, 0, 0),
|
||||||
@@ -30,5 +30,5 @@ VALUES
|
|||||||
|
|
||||||
-- +goose Down
|
-- +goose Down
|
||||||
|
|
||||||
DROP TABLE IF EXISTS b2b_tracker_routes;
|
DROP TABLE IF EXISTS b2b_routes;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user