package models import ( "bytes" "html/template" "math" "github.com/astaxie/beego/orm" "github.com/lifei6671/mindoc/conf" "fmt" ) type DocumentTree struct { DocumentId int `json:"id"` DocumentName string `json:"text"` ParentId interface{} `json:"parent"` Identify string `json:"identify"` BookIdentify string `json:"-"` Version int64 `json:"version"` State *DocumentSelected `json:"-"` AAttrs map[string]interface{} `json:"a_attr"` } type DocumentSelected struct { Selected bool `json:"selected"` Opened bool `json:"opened"` } //获取项目的文档树状结构 func (m *Document) FindDocumentTree(bookId int) ([]*DocumentTree, error) { o := orm.NewOrm() trees := make([]*DocumentTree, 0) var docs []*Document count, err := o.QueryTable(m).Filter("book_id", bookId).OrderBy("order_sort", "document_id").Limit(math.MaxInt32).All(&docs, "document_id", "version", "document_name", "parent_id", "identify","is_open") if err != nil { return trees, err } book, _ := NewBook().Find(bookId) trees = make([]*DocumentTree, count) for index, item := range docs { tree := &DocumentTree{} if index == 0 { tree.State = &DocumentSelected{Selected: true, Opened: true} tree.AAttrs = map[string]interface{}{ "is_open": true} }else if item.IsOpen == 1 { tree.State = &DocumentSelected{Selected: false, Opened: true} tree.AAttrs = map[string]interface{}{ "is_open": true} } tree.DocumentId = item.DocumentId tree.Identify = item.Identify tree.Version = item.Version tree.BookIdentify = book.Identify if item.ParentId > 0 { tree.ParentId = item.ParentId } else { tree.ParentId = "#" } tree.DocumentName = item.DocumentName trees[index] = tree } return trees, nil } func (m *Document) CreateDocumentTreeForHtml(bookId, selectedId int) (string, error) { trees, err := m.FindDocumentTree(bookId) if err != nil { return "", err } parentId := getSelectedNode(trees, selectedId) buf := bytes.NewBufferString("") getDocumentTree(trees, 0, selectedId, parentId, buf) return buf.String(), nil } //使用递归的方式获取指定ID的顶级ID func getSelectedNode(array []*DocumentTree, parent_id int) int { for _, item := range array { if _, ok := item.ParentId.(string); ok && item.DocumentId == parent_id { return item.DocumentId } else if pid, ok := item.ParentId.(int); ok && item.DocumentId == parent_id { return getSelectedNode(array, pid) } } return 0 } func getDocumentTree(array []*DocumentTree, parentId int, selectedId int, selectedParentId int, buf *bytes.Buffer) { buf.WriteString("") }