1
0
forked from x/icebergs
This commit is contained in:
shylinux 2020-06-09 11:11:22 +08:00
parent 20d2c0137e
commit 012cce411a

View File

@ -4,6 +4,8 @@ import (
"github.com/shylinux/icebergs" "github.com/shylinux/icebergs"
"github.com/shylinux/icebergs/base/web" "github.com/shylinux/icebergs/base/web"
"github.com/shylinux/toolkits" "github.com/shylinux/toolkits"
"time"
) )
const ( const (
@ -23,9 +25,9 @@ func _task_list(m *ice.Message, zone string, id string, field ...interface{}) {
m.Richs(TASK, nil, kit.Select("*", zone), func(key string, val map[string]interface{}) { m.Richs(TASK, nil, kit.Select("*", zone), func(key string, val map[string]interface{}) {
if zone = kit.Format(kit.Value(val, "meta.zone")); id == "" { if zone = kit.Format(kit.Value(val, "meta.zone")); id == "" {
m.Grows(TASK, kit.Keys("hash", key), "", "", func(index int, value map[string]interface{}) { m.Grows(TASK, kit.Keys("hash", key), "", "", func(index int, value map[string]interface{}) {
m.Push(zone, value, []string{"time"}) m.Push(zone, value, []string{"begin_time"})
m.Push("zone", zone) m.Push("zone", zone)
m.Push(zone, value, []string{"id", "status", "name", "text"}) m.Push(zone, value, []string{"id", "status", "type", "name", "text"})
}) })
return return
} }
@ -52,8 +54,13 @@ func _task_insert(m *ice.Message, zone, kind, name, text, begin_time, close_time
func _task_modify(m *ice.Message, zone, id, pro, set, old string) { func _task_modify(m *ice.Message, zone, id, pro, set, old string) {
m.Richs(TASK, nil, kit.Select("*", zone), func(key string, val map[string]interface{}) { m.Richs(TASK, nil, kit.Select("*", zone), func(key string, val map[string]interface{}) {
m.Grows(TASK, kit.Keys("hash", key), "id", id, func(index int, value map[string]interface{}) { m.Grows(TASK, kit.Keys("hash", key), "id", id, func(index int, value map[string]interface{}) {
m.Log_MODIFY("zone", zone, "id", id, "key", pro, "value", set, "old", old) switch key {
kit.Value(value, pro, set) case "id", "time":
m.Info("not allow %v", key)
default:
m.Log_MODIFY("zone", zone, "id", id, "key", pro, "value", set, "old", old)
kit.Value(value, pro, set)
}
}) })
}) })
} }
@ -104,23 +111,56 @@ var Index = &ice.Context{Name: "team", Help: "团队中心",
PLAN: {Name: "plan scale:select=day|week|month|year begin_time=@date end_time=@date auto", Help: "计划", Meta: kit.Dict( PLAN: {Name: "plan scale:select=day|week|month|year begin_time=@date end_time=@date auto", Help: "计划", Meta: kit.Dict(
"display", "/plugin/local/team/miss.js", "detail", []string{"prepare", "process", "finish", "cancel"}, "display", "/plugin/local/team/miss.js", "detail", []string{"prepare", "process", "finish", "cancel"},
), Action: map[string]*ice.Action{ ), Action: map[string]*ice.Action{
"modify": {Name: "modify key value old", Help: "编辑", Hand: func(m *ice.Message, arg ...string) { "insert": {Name: "insert begin_time type name text", Help: "添加", Hand: func(m *ice.Message, arg ...string) {
_task_modify(m, m.Option("zone"), m.Option("id"), arg[0], arg[1], arg[2]) _task_insert(m, arg[0], arg[1], arg[2], arg[3], arg[4], arg[5])
}}, }},
"delete": {Name: "delete key value", Help: "删除", Hand: func(m *ice.Message, arg ...string) { "delete": {Name: "delete key value", Help: "删除", Hand: func(m *ice.Message, arg ...string) {
_task_delete(m, m.Option("zone"), m.Option("id")) _task_delete(m, m.Option("zone"), m.Option("id"))
}}, }},
"modify": {Name: "modify key value old", Help: "编辑", Hand: func(m *ice.Message, arg ...string) {
_task_modify(m, m.Option("zone"), m.Option("id"), arg[0], arg[1], arg[2])
}},
}, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) { }, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
begin_time := time.Now()
if len(arg) > 1 {
begin_time, _ = time.ParseInLocation("2006-01-02 15:04:05", arg[1], time.Local)
}
end_time := begin_time
if len(arg) > 2 {
end_time, _ = time.ParseInLocation("2006-01-02 15:04:05", arg[2], time.Local)
}
switch arg[0] { switch arg[0] {
case "day": case "day":
begin_time = begin_time.Add(-time.Duration(begin_time.UnixNano()) % (24 * time.Hour))
end_time = begin_time.Add(24 * time.Hour)
case "week": case "week":
begin_time = begin_time.Add(-time.Duration(begin_time.UnixNano())%(24*time.Hour) - time.Duration(begin_time.Weekday())*24*time.Hour)
end_time = begin_time.Add(7 * 24 * time.Hour)
case "month": case "month":
case "months": case "months":
case "year": case "year":
case "long": case "long":
} }
_task_list(m, "", "") begin_time = begin_time.Add(-8 * time.Hour)
end_time = end_time.Add(-8 * time.Hour)
m.Debug("begin_time: %v %v", begin_time, end_time)
m.Richs(TASK, nil, kit.Select("*", m.Option("zone")), func(key string, val map[string]interface{}) {
zone := kit.Format(kit.Value(val, "meta.zone"))
m.Grows(TASK, kit.Keys("hash", key), "", "", func(index int, value map[string]interface{}) {
begin, _ := time.ParseInLocation("2006-01-02 15:04:05", kit.Format(value["begin_time"]), time.Local)
m.Debug("begin: %v", begin)
if begin_time.Before(begin) && begin.Before(end_time) {
m.Push(zone, value, []string{"begin_time"})
m.Push("zone", zone)
m.Push(zone, value, []string{"id", "status", "type", "name", "text"})
}
})
})
}}, }},
"miss": {Name: "miss", Help: "miss"}, "miss": {Name: "miss", Help: "miss"},
}, },