前面从后台设置——新建项目无限级目录——向任意目录中添加成果——成果包含文章、非PDF附件和pdf附件,如果附件多于一个则点击显示列表,如果是一个则点击直接打开或下载,如果没有则显示空。
本想前端来实现,可是不行,只好用后端来实现了。
//取得某个侧栏id下的成果给table
func (c *ProdController) GetProducts() {
id := c.Ctx.Input.Param(":id")
// beego.Info(id)
c.Data["Id"] = id
var idNum int64
var err error
if id != "" {
//id转成64为
idNum, err = strconv.ParseInt(id, 10, 64)
if err != nil {
beego.Error(err)
}
//由成果id(后台传过来的行id)取得侧栏目录id
// prod, err := models.GetProd(idNum)
// if err != nil {
// beego.Error(err)
// }
// //由proj id取得url
// Url, _, err = GetUrlPath(prod.ProjectId)
// if err != nil {
// beego.Error(err)
// }
// beego.Info(Url)
} else {
}
//根据id取得所有成果
products, err := models.GetProducts(idNum)
if err != nil {
beego.Error(err)
}
//由proj id取得url
Url, _, err := GetUrlPath(idNum)
if err != nil {
beego.Error(err)
}
beego.Info(Url)
link := make([]ProductLink, 0)
Attachslice := make([]AttachmentLink, 0)
Pdfslice := make([]PdfLink, 0)
for _, w := range products {
//取到每个成果的附件(模态框打开);pdf、文章——新窗口打开
//循环成果
//每个成果取到所有附件
//一个附件则直接打开/下载;2个以上则打开模态框
Attachments, err := models.GetAttachments(w.Id)
if err != nil {
beego.Error(err)
}
//对成果进行循环
//赋予url
//如果是一个成果,直接给url;如果大于1个,则是数组:这个在前端实现
// http.ServeFile(ctx.ResponseWriter, ctx.Request, filePath)
linkarr := make([]ProductLink, 1)
linkarr[0].Id = w.Id
linkarr[0].Code = w.Code
linkarr[0].Title = w.Title
linkarr[0].Label = w.Label
linkarr[0].Uid = w.Uid
linkarr[0].Principal = w.Principal
linkarr[0].ProjectId = w.ProjectId
linkarr[0].Content = w.Content
linkarr[0].Created = w.Created
linkarr[0].Updated = w.Updated
linkarr[0].Views = w.Views
for _, v := range Attachments {
// fileext := path.Ext(v.FileName)
if path.Ext(v.FileName) != ".pdf" && path.Ext(v.FileName) != ".PDF" {
attacharr := make([]AttachmentLink, 1)
attacharr[0].Id = v.Id
attacharr[0].Title = v.FileName
attacharr[0].Link = Url
Attachslice = append(Attachslice, attacharr...)
} else if path.Ext(v.FileName) == ".pdf" || path.Ext(v.FileName) == ".PDF" {
pdfarr := make([]PdfLink, 1)
pdfarr[0].Id = v.Id
pdfarr[0].Title = v.FileName
pdfarr[0].Link = Url
Pdfslice = append(Pdfslice, pdfarr...)
}
}
linkarr[0].Pdflink = Pdfslice
linkarr[0].Attachmentlink = Attachslice
Attachslice = make([]AttachmentLink, 0) //再把slice置0
Pdfslice = make([]PdfLink, 0) //再把slice置0
link = append(link, linkarr...)
}
c.Data["json"] = link //products
c.ServeJSON()
// c.Data["json"] = root
// c.ServeJSON()
}