245 lines
6.2 KiB
Go
245 lines
6.2 KiB
Go
package rigger
|
||
|
||
import (
|
||
"fmt"
|
||
"net/http"
|
||
"strings"
|
||
|
||
"ciyon/web/admin"
|
||
c "ciyon/zciyon"
|
||
)
|
||
|
||
func Cata_init(w http.ResponseWriter, r *http.Request) bool {
|
||
post := c.NewCiyPost(w, r)
|
||
_, userid := admin.Verifyfast(r, c.CiyDB, post)
|
||
if userid == 0 {
|
||
return false
|
||
}
|
||
cbid := post.Getint("cbid")
|
||
ext := post.Get("ext")
|
||
issub := (post.Get("issub") == "yes")
|
||
ismulti := (post.Get("ismulti") == "yes")
|
||
cname := ""
|
||
code := ""
|
||
if cbid == 0 {
|
||
code = post.Get("code")
|
||
csql := c.NewCiySQL("zc_cata")
|
||
csql.Where("codeid", code)
|
||
csql.Where("cbid=0")
|
||
cbrow, _ := c.CiyDB.Getone(csql)
|
||
if cbrow == nil {
|
||
return c.ErrJSON(w, "代码库未找到code="+code)
|
||
}
|
||
cbid = c.Toint(cbrow["id"])
|
||
cname = c.Tostr(cbrow["name"])
|
||
} else {
|
||
csql := c.NewCiySQL("zc_cata")
|
||
csql.Where("id", cbid)
|
||
csql.Where("cbid=0")
|
||
cbrow, _ := c.CiyDB.Getone(csql)
|
||
if cbrow == nil {
|
||
return c.ErrJSON(w, "代码库未找到cbid="+c.Tostr(cbid))
|
||
}
|
||
cname = c.Tostr(cbrow["name"])
|
||
code = c.Tostr(cbrow["codeid"])
|
||
}
|
||
csql := c.NewCiySQL("zc_cata")
|
||
csql.Where("cbid", cbid)
|
||
csql.Order("csort,id")
|
||
rows, _, err := c.CiyDB.Get(csql)
|
||
if err != nil {
|
||
return c.ErrJSON(w, "读取错误", err)
|
||
}
|
||
rows = append(rows, map[string]any{
|
||
"id": 0,
|
||
"name": "",
|
||
"csort": 10,
|
||
"isuse": 1,
|
||
})
|
||
ret := map[string]any{}
|
||
ret["list"] = rows
|
||
if post.Getbool("field") {
|
||
field := map[string]map[string]any{}
|
||
fshow := ""
|
||
c.FieldAdd(&field, &fshow, -1, "name", cname)
|
||
c.FieldAdd(&field, &fshow, -1, "codeid", "代码|")
|
||
if ext != "" {
|
||
c.FieldAdd(&field, &fshow, -1, "extdata", ext)
|
||
}
|
||
c.FieldAdd(&field, &fshow, -1, "isuse", "启用")
|
||
c.FieldAdd(&field, &fshow, -1, "csort", "排序|")
|
||
c.FieldAdd(&field, &fshow, -1, "clas", "样式")
|
||
c.FieldAdd(&field, &fshow, -1, "_btn", "操作")
|
||
|
||
field["clas"]["thwidth"] = "7em"
|
||
field["codeid"]["thwidth"] = "6em"
|
||
field["csort"]["thwidth"] = "5em"
|
||
ret["fshow"] = strings.TrimLeft(fshow, ",")
|
||
ret["field"] = field
|
||
}
|
||
if post.Getbool("once") {
|
||
once := map[string]any{}
|
||
input := make([]map[string]string, 0)
|
||
input = append(input, map[string]string{
|
||
"form": "name",
|
||
"type": "input",
|
||
"name": cname,
|
||
"prop": ` style="width:8em;"`,
|
||
})
|
||
input = append(input, map[string]string{
|
||
"form": "codeid",
|
||
"type": "input",
|
||
"name": "代码",
|
||
"prop": ` style="width:8em;"`,
|
||
})
|
||
if ext != "" {
|
||
input = append(input, map[string]string{
|
||
"form": "extdata",
|
||
"type": "input",
|
||
"name": ext,
|
||
"prop": ` style="width:8em;"`,
|
||
})
|
||
}
|
||
once["input"] = input
|
||
ret["cbid"] = cbid
|
||
ret["issub"] = issub
|
||
ret["ismulti"] = ismulti
|
||
ret["codename"] = code
|
||
ret["once"] = once
|
||
}
|
||
return c.SuccJSON(w, r, ret)
|
||
}
|
||
func Cata_update(w http.ResponseWriter, r *http.Request) bool {
|
||
post := c.NewCiyPost(w, r)
|
||
_, userid := admin.Verifyfast(r, c.CiyDB, post)
|
||
if userid == 0 {
|
||
return false
|
||
}
|
||
if admin.Nopower(c.CiyDB, userid, "p601pd") {
|
||
return c.ErrJSON(w, "您未被授权操作")
|
||
}
|
||
id := post.Getint("id")
|
||
cbid := post.Getint("cbid")
|
||
codeid := post.Get("codeid")
|
||
name := post.Get("name")
|
||
if name == "" {
|
||
return c.ErrJSON(w, "请填写名称")
|
||
}
|
||
upid := post.Getint("upid")
|
||
csort := post.Getint("csort")
|
||
extdata := post.Get("extdata")
|
||
isuse := post.Getint("isuse")
|
||
clas := post.Get("clas")
|
||
var err error
|
||
var datarow map[string]any
|
||
if id > 0 {
|
||
csql := c.NewCiySQL("zc_cata")
|
||
csql.Where("id", id)
|
||
datarow, err = c.CiyDB.Getone(csql)
|
||
if datarow == nil {
|
||
return c.ErrJSON(w, "数据不存在", err)
|
||
}
|
||
}
|
||
updata := map[string]any{}
|
||
err = c.CiyDB.Tran(func() error {
|
||
var csql *c.CiySQL
|
||
csql = c.NewCiySQL("zc_cata")
|
||
csql.Where("cbid", cbid)
|
||
csql.Where("codeid", codeid)
|
||
csql.Column("id")
|
||
chkid := c.Toint(c.CiyDB.Get1(csql))
|
||
if chkid > 0 && ((id > 0 && chkid != id) || id == 0) {
|
||
return fmt.Errorf("代码值重复")
|
||
}
|
||
updata["name"] = name
|
||
updata["codeid"] = codeid
|
||
updata["cbid"] = cbid
|
||
updata["upid"] = upid
|
||
updata["isuse"] = isuse
|
||
updata["csort"] = csort
|
||
updata["clas"] = clas
|
||
updata["extdata"] = extdata
|
||
csql = c.NewCiySQL("zc_cata")
|
||
if id > 0 {
|
||
csql.Where("id", id)
|
||
_, err = c.CiyDB.Update(csql, updata)
|
||
} else {
|
||
id, err = c.CiyDB.Insert(csql, updata)
|
||
}
|
||
updata["newid"] = id
|
||
if err != nil {
|
||
return fmt.Errorf("更新失败:%v", err)
|
||
}
|
||
admin.SaveLogDB(c.CiyDB, "zc_cata", datarow, updata)
|
||
return nil
|
||
})
|
||
if err != nil {
|
||
return c.ErrJSON(w, "事务"+err.Error())
|
||
}
|
||
c.CiyDB.Execute("update zc_online set usrchg=2")
|
||
ret := map[string]any{}
|
||
ret["data"] = updata
|
||
return c.SuccJSON(w, r, ret)
|
||
}
|
||
func Cata_del(w http.ResponseWriter, r *http.Request) bool {
|
||
post := c.NewCiyPost(w, r)
|
||
_, userid := admin.Verifyfast(r, c.CiyDB, post)
|
||
if userid == 0 {
|
||
return false
|
||
}
|
||
if admin.Nopower(c.CiyDB, userid, "p601pd") {
|
||
return c.ErrJSON(w, "您未被授权操作")
|
||
}
|
||
ids := post.Get("ids")
|
||
if ids == "" {
|
||
return c.ErrJSON(w, "请选择至少一条")
|
||
}
|
||
cbid := post.Getint("cbid")
|
||
var csql *c.CiySQL
|
||
csql = c.NewCiySQL("zc_cata")
|
||
csql.Where("cbid=0")
|
||
csql.Where("id", cbid)
|
||
cbrow, _ := c.CiyDB.Getone(csql)
|
||
if cbrow == nil {
|
||
return c.ErrJSON(w, "代码库未找到cbid="+c.Tostr(cbid))
|
||
}
|
||
exs := strings.Split(c.Tostr(cbrow["extdata"]), "\n")
|
||
csql = c.NewCiySQL("zc_cata")
|
||
csql.Where("id in", ids)
|
||
rows, _, _ := c.CiyDB.Get(csql)
|
||
vids := make([]int, 0)
|
||
err := c.CiyDB.Tran(func() error {
|
||
for _, row := range rows {
|
||
delid := c.Toint(row["id"])
|
||
csql = c.NewCiySQL("zc_cata")
|
||
csql.Where("upid", delid)
|
||
csql.Where("cbid", row["cbid"])
|
||
downcnt := c.Toint(c.CiyDB.Get1(csql))
|
||
if downcnt > 0 {
|
||
return fmt.Errorf("[%v]有%v个子码,请先删除子码", row["name"], downcnt)
|
||
}
|
||
for _, exn := range exs {
|
||
if exn == "" {
|
||
continue
|
||
}
|
||
tabf := strings.Split(exn, ",")
|
||
if len(tabf) == 1 {
|
||
tabf = append(tabf, c.Tostr(cbrow["codeid"]))
|
||
}
|
||
c.Delcheck(c.CiyDB, c.Toint(row["codeid"]), tabf[0], tabf[1], tabf[0]+"数据")
|
||
}
|
||
c.Delme(c.CiyDB, delid, "zc_cata")
|
||
admin.SaveLogDB(c.CiyDB, "zc_cata", row, nil)
|
||
vids = append(vids, delid)
|
||
}
|
||
return nil
|
||
})
|
||
if err != nil {
|
||
return c.ErrJSON(w, "事务"+err.Error())
|
||
}
|
||
c.CiyDB.Execute("update zc_online set usrchg=2")
|
||
ret := map[string]any{}
|
||
ret["ids"] = vids
|
||
return c.SuccJSON(w, r, ret)
|
||
}
|