From 321201e7ddacc9722601d5ddacc08e914318047f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?piexlMax=28=E5=A5=87=E6=B7=BC?= Date: Tue, 19 Nov 2024 17:06:55 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=87=AA=E5=8A=A8=E5=8C=96=E6=A0=91?= =?UTF-8?q?=E5=BD=A2=E7=BB=93=E6=9E=84=E5=AE=8C=E7=BB=93?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/model/common/basetypes.go | 2 +- server/resource/package/server/model/model.go.tpl | 12 ++++++------ .../resource/package/server/service/service.go.tpl | 8 +++----- .../resource/plugin/server/model/model.go.template | 14 +++++++------- .../plugin/server/service/service.go.template | 4 ++-- server/utils/fmt_plus.go | 3 +-- 6 files changed, 20 insertions(+), 23 deletions(-) diff --git a/server/model/common/basetypes.go b/server/model/common/basetypes.go index 3c27ed0242..1a133d5ad2 100644 --- a/server/model/common/basetypes.go +++ b/server/model/common/basetypes.go @@ -37,7 +37,7 @@ func (m *JSONMap) Scan(value interface{}) error { type TreeNode[T any] interface { GetChildren() []T - SetChildren(in *T, children T) + SetChildren(children T) GetID() int GetParentID() int } diff --git a/server/resource/package/server/model/model.go.tpl b/server/resource/package/server/model/model.go.tpl index ccb7f1dde3..82f33dab8c 100644 --- a/server/resource/package/server/model/model.go.tpl +++ b/server/resource/package/server/model/model.go.tpl @@ -73,7 +73,7 @@ type {{.StructName}} struct { DeletedBy uint `gorm:"column:deleted_by;comment:删除者"` {{- end }} {{- if .IsTree }} - Children []{{.StructName}} `json:"children" gorm:"-"` //子节点 + Children []*{{.StructName}} `json:"children" gorm:"-"` //子节点 ParentID int `json:"parentID" gorm:"column:parent_id;comment:父节点"` {{- end }} {{- end }} @@ -88,22 +88,22 @@ func ({{.StructName}}) TableName() string { {{if .IsTree }} // GetChildren 实现TreeNode接口 -func (s {{.StructName}}) GetChildren() []{{.StructName}} { +func (s *{{.StructName}}) GetChildren() []*{{.StructName}} { return s.Children } // SetChildren 实现TreeNode接口 -func (s {{.StructName}}) SetChildren(in *{{.StructName}},children {{.StructName}}) { - in.Children = append(in.Children, children) +func (s *{{.StructName}}) SetChildren(children *{{.StructName}}) { + s.Children = append(s.Children, children) } // GetID 实现TreeNode接口 -func (s {{.StructName}}) GetID() int { +func (s *{{.StructName}}) GetID() int { return int({{if not .GvaModel}}*{{- end }}s.{{.PrimaryField.FieldName}}) } // GetParentID 实现TreeNode接口 -func (s {{.StructName}}) GetParentID() int { +func (s *{{.StructName}}) GetParentID() int { return s.ParentID } {{ end }} diff --git a/server/resource/package/server/service/service.go.tpl b/server/resource/package/server/service/service.go.tpl index 77a4946b6f..0d6e6a83c9 100644 --- a/server/resource/package/server/service/service.go.tpl +++ b/server/resource/package/server/service/service.go.tpl @@ -63,15 +63,13 @@ import ( {{- if not .IsTree}} {{.Package}}Req "{{.Module}}/model/{{.Package}}/request" {{- else }} + "{{.Module}}/utils" "errors" {{- end }} {{- if .AutoCreateResource }} "gorm.io/gorm" {{- end}} {{- end }} -{{- if .IsTree }} - "{{.Module}}/utils" -{{- end }} ) type {{.StructName}}Service struct {} @@ -151,10 +149,10 @@ func ({{.Abbreviation}}Service *{{.StructName}}Service)Get{{.StructName}}({{.Pri {{- if .IsTree }} // Get{{.StructName}}InfoList 分页获取{{.Description}}记录,Tree模式下不添加分页和搜索 // Author [yourname](https://github.com/yourname) -func ({{.Abbreviation}}Service *{{.StructName}}Service)Get{{.StructName}}InfoList() (list []{{.Package}}.{{.StructName}},err error) { +func ({{.Abbreviation}}Service *{{.StructName}}Service)Get{{.StructName}}InfoList() (list []*{{.Package}}.{{.StructName}},err error) { // 创建db db := {{$db}}.Model(&{{.Package}}.{{.StructName}}{}) - var {{.Abbreviation}}s []{{.Package}}.{{.StructName}} + var {{.Abbreviation}}s []*{{.Package}}.{{.StructName}} err = db.Find(&{{.Abbreviation}}s).Error diff --git a/server/resource/plugin/server/model/model.go.template b/server/resource/plugin/server/model/model.go.template index 503eb0a36e..2f1d35dd13 100644 --- a/server/resource/plugin/server/model/model.go.template +++ b/server/resource/plugin/server/model/model.go.template @@ -72,7 +72,7 @@ type {{.StructName}} struct { DeletedBy uint `gorm:"column:deleted_by;comment:删除者"` {{- end }} {{- if .IsTree }} - Children []{{.StructName}} `json:"children" gorm:"-"` //子节点 + Children []*{{.StructName}} `json:"children" gorm:"-"` //子节点 ParentID int `json:"parentID" gorm:"column:parent_id;comment:父节点"` {{- end }} {{- end }} @@ -86,24 +86,24 @@ func ({{.StructName}}) TableName() string { {{ end }} -{{ if .IsTree }} +{{if .IsTree }} // GetChildren 实现TreeNode接口 -func (s {{.StructName}}) GetChildren() []{{.StructName}} { +func (s *{{.StructName}}) GetChildren() []*{{.StructName}} { return s.Children } // SetChildren 实现TreeNode接口 -func (s {{.StructName}}) SetChildren(in *{{.StructName}},children {{.StructName}}) { - in.Children = append(in.Children, children) +func (s *{{.StructName}}) SetChildren(children *{{.StructName}}) { + s.Children = append(s.Children, children) } // GetID 实现TreeNode接口 -func (s {{.StructName}}) GetID() int { +func (s *{{.StructName}}) GetID() int { return int({{if not .GvaModel}}*{{- end }}s.{{.PrimaryField.FieldName}}) } // GetParentID 实现TreeNode接口 -func (s {{.StructName}}) GetParentID() int { +func (s *{{.StructName}}) GetParentID() int { return s.ParentID } {{ end }} diff --git a/server/resource/plugin/server/service/service.go.template b/server/resource/plugin/server/service/service.go.template index ce6ae4aa25..b0da0fa0b8 100644 --- a/server/resource/plugin/server/service/service.go.template +++ b/server/resource/plugin/server/service/service.go.template @@ -160,10 +160,10 @@ func (s *{{.Abbreviation}}) Get{{.StructName}}({{.PrimaryField.FieldJson}} strin {{- if .IsTree }} // Get{{.StructName}}InfoList 分页获取{{.Description}}记录,Tree模式下不添加分页和搜索 // Author [yourname](https://github.com/yourname) -func (s *{{.Abbreviation}}) Get{{.StructName}}InfoList() (list []model.{{.StructName}},err error) { +func (s *{{.Abbreviation}}) Get{{.StructName}}InfoList() (list []*model.{{.StructName}},err error) { // 创建db db := {{$db}}.Model(&model.{{.StructName}}{}) - var {{.Abbreviation}}s []model.{{.StructName}} + var {{.Abbreviation}}s []*model.{{.StructName}} err = db.Find(&{{.Abbreviation}}s).Error diff --git a/server/utils/fmt_plus.go b/server/utils/fmt_plus.go index 6b24010104..65f3e13253 100644 --- a/server/utils/fmt_plus.go +++ b/server/utils/fmt_plus.go @@ -93,8 +93,7 @@ func BuildTree[T common.TreeNode[T]](nodes []T) []T { for i := range nodes { if nodes[i].GetParentID() != 0 { parent := nodeMap[nodes[i].GetParentID()] - parent.SetChildren(&parent, nodes[i]) - nodeMap[nodes[i].GetParentID()] = parent + parent.SetChildren(nodes[i]) } }