mirror of
https://shylinux.com/x/enterprise
synced 2025-04-25 17:18:06 +08:00
add some
This commit is contained in:
parent
20c60016fc
commit
9f7c06404d
@ -1,7 +1,15 @@
|
||||
package gongyinglian
|
||||
|
||||
import "shylinux.com/x/ice"
|
||||
import (
|
||||
"shylinux.com/x/ice"
|
||||
kit "shylinux.com/x/toolkits"
|
||||
)
|
||||
|
||||
type brand struct{ Value }
|
||||
|
||||
func (s brand) List(m *ice.Message, arg ...string) {
|
||||
s.Value.List(m, arg...)
|
||||
kit.If(!s.IsBoss(m), func() { m.PushAction().Action().SetResult() })
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(brand{}) }
|
||||
|
@ -1,7 +1,6 @@
|
||||
package gongyinglian
|
||||
|
||||
import (
|
||||
"path"
|
||||
"shylinux.com/x/ice"
|
||||
kit "shylinux.com/x/toolkits"
|
||||
|
||||
@ -70,32 +69,6 @@ func (s Table) CheckRole(m *ice.Message, arg ...string) *ice.Message {
|
||||
m.WarnNotRight(!kit.IsIn(role.String(), append(arg, UserStoreCreator.String())...), role.String())
|
||||
return m
|
||||
}
|
||||
func (s Table) checkRole(m *ice.Message, arg ...UserStoreRole) bool {
|
||||
kit.If(len(arg) == 0, func() { arg = append(arg, UserStoreBoss) })
|
||||
role := s.userStoreRole(m, m.Option(model.STORE_UID))
|
||||
for _, v := range append(arg, UserStoreCreator) {
|
||||
if role == v {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
func (s Table) userStoreRole(m *ice.Message, arg ...string) UserStoreRole {
|
||||
msg := m.Spawn()
|
||||
userStore{}.Fields(msg, model.ROLE)
|
||||
msg = msg.Cmd(userStore{}, s.Select, model.STORE_UID, arg[0], model.USER_UID, m.Option(model.USER_UID))
|
||||
if msg.Length() > 0 {
|
||||
return UserStoreRole(kit.Int(msg.Append(model.ROLE)))
|
||||
} else {
|
||||
return -1
|
||||
}
|
||||
}
|
||||
func (s Table) checkListRole(m *ice.Message, arg ...string) bool {
|
||||
if (len(arg) == 0 && m.Option(model.STORE_UID) != "" && !s.checkRole(m, UserStoreBoss)) || (len(arg) == 1 && !s.checkRole(m.Options(model.STORE_UID, arg[0]), UserStoreBoss)) {
|
||||
return false
|
||||
}
|
||||
return true
|
||||
}
|
||||
func (s Table) checkOrderRole(m *ice.Message, arg ...string) bool {
|
||||
user_uid := m.Option(model.USER_UID)
|
||||
msg := m.Cmd(Order{}, s.Select, "(from_store_uid = ? OR to_store_uid = ?) AND uid = ?", arg[0], arg[0], arg[1])
|
||||
@ -104,6 +77,13 @@ func (s Table) checkOrderRole(m *ice.Message, arg ...string) bool {
|
||||
}
|
||||
return true
|
||||
}
|
||||
func (s Table) IsBoss(m *ice.Message) bool {
|
||||
return s.IsLeader(m)
|
||||
}
|
||||
func (s Table) IsWorker(m *ice.Message) bool {
|
||||
role := UserStoreRole(kit.Int(m.Option(model.USER_ROLE)))
|
||||
return role == UserStoreCreator || role == UserStoreWorker
|
||||
}
|
||||
|
||||
type Tables struct{ Table }
|
||||
|
||||
@ -111,29 +91,17 @@ func (s Tables) BeforeMigrate(m *ice.Message, arg ...string) {}
|
||||
|
||||
type Value struct {
|
||||
Table
|
||||
fields string `data:"name,info"`
|
||||
fields string `data:"name,info,user_uid"`
|
||||
create string `name:"create name info" role:"boss"`
|
||||
modify string `name:"modify name info" role:"boss"`
|
||||
remove string `name:"remove" role:"boss"`
|
||||
}
|
||||
|
||||
func (s Value) Create(m *ice.Message, arg ...string) {
|
||||
s.Table.ValueCreate(m, s.transPrice(m, arg...)...)
|
||||
s.ValueCreate(m, s.transPrice(m, arg...)...)
|
||||
}
|
||||
func (s Value) Modify(m *ice.Message, arg ...string) {
|
||||
s.Table.ValueModify(m, s.transPrice(m, arg...)...)
|
||||
}
|
||||
func (s Value) Remove(m *ice.Message, arg ...string) {
|
||||
s.Table.ValueRemove(m, arg...)
|
||||
}
|
||||
func (s Value) List(m *ice.Message, arg ...string) {
|
||||
s.Table.ValueList(m, arg)
|
||||
if m.Length() == 0 {
|
||||
m.EchoInfoButton("")
|
||||
}
|
||||
if m.Exists(path.Join(path.Dir(kit.FileLines(1)), m.CommandKey()+".js")) {
|
||||
m.Display(m.CommandKey() + ".js")
|
||||
}
|
||||
s.ValueModify(m, s.transPrice(m, arg...)...)
|
||||
}
|
||||
func (s Value) transPrice(m *ice.Message, arg ...string) []string {
|
||||
for i := 0; i < len(arg); i += 2 {
|
||||
@ -148,11 +116,11 @@ func (s Value) transPrice(m *ice.Message, arg ...string) []string {
|
||||
type Relative struct{ Table }
|
||||
|
||||
func (s Relative) List(m *ice.Message, arg ...string) {
|
||||
if !s.checkListRole(m, arg...) {
|
||||
if !s.IsBoss(m) && !s.IsWorker(m) {
|
||||
return
|
||||
}
|
||||
order := Order{}
|
||||
s.Tables(m, Order{}).FieldsWithCreatedAT(m, order,
|
||||
s.Tables(m, Order{}).FieldsWithCreatedAT(m, m.CommandKey(),
|
||||
s.AS(model.TO_USER_UID, model.USER_UID), m.CommandKey()+"_"+model.STATUS,
|
||||
s.Key(order, model.AMOUNT), s.Key(order, model.TOTAL),
|
||||
model.COMPANY_UID, model.OPEN_ID, model.ORDER_UID,
|
||||
|
@ -9,19 +9,15 @@ import (
|
||||
|
||||
type expense struct {
|
||||
Value
|
||||
fields string `data:"expense_type,amount,name,info"`
|
||||
create string `name:"create expense_type* amount* name info" role:"boss"`
|
||||
modify string `name:"modify amount* name info" role:"boss"`
|
||||
fields string `data:"expense_type,amount,name,info,from_user_uid,to_user_uid AS user_uid"`
|
||||
create string `name:"create expense_type* amount* name info" role:"boss,worker"`
|
||||
modify string `name:"modify amount* name info" role:"boss,worker"`
|
||||
list string `name:"list store_uid uid auto" role:"boss,worker"`
|
||||
}
|
||||
|
||||
func (s expense) Create(m *ice.Message, arg ...string) {
|
||||
arg = kit.TransArgKeys(arg, model.EXPENSE_TYPE, model.TYPE)
|
||||
s.Value.Create(m, kit.Simple(arg, model.FROM_USER_UID, m.Option(model.USER_UID))...)
|
||||
}
|
||||
func (s expense) List(m *ice.Message, arg ...string) {
|
||||
if s.checkListRole(m, arg...) {
|
||||
s.Value.List(m, arg...)
|
||||
}
|
||||
arg = kit.TransArgKeys(s.transPrice(m, arg...), model.EXPENSE_TYPE, model.TYPE)
|
||||
s.Insert(m, kit.Simple(arg, model.FROM_USER_UID, m.Option(model.USER_UID), m.OptionSimple(model.STORE_UID))...)
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(expense{}) }
|
||||
|
@ -1,8 +1,8 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.user_name, can.onimport.textView(can, value, "express_status", mdb.STATUS)]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value)]},
|
||||
{view: html.TITLE, list: [value.user_name]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name+":", value.open_id]},
|
||||
{view: html.STATUS, list: ["订单:", value.order_uid.slice(0, 6), "金额:", value.amount||"0", "数量:", value.total||"0"]},
|
||||
] })
|
||||
|
@ -9,19 +9,19 @@ import (
|
||||
|
||||
type goods struct {
|
||||
Product
|
||||
create string `name:"create shop_uid*:select name* info price stock unit" role:"boss"`
|
||||
market string `name:"market domain_uid* title* content" role:"boss"`
|
||||
create string `name:"create shop_uid*:select name* info price stock unit" role:"boss"`
|
||||
marketInsert string `name:"marketInsert domain_uid* title* content" role:"boss"`
|
||||
}
|
||||
|
||||
func (s goods) Create(m *ice.Message, arg ...string) {
|
||||
s.Product.Create(m, kit.Simple(model.PRODUCT_TYPE, ProductGoods, arg)...)
|
||||
}
|
||||
func (s goods) Market(m *ice.Message, arg ...string) {
|
||||
s.MarketInsert(m, arg...)
|
||||
}
|
||||
func (s goods) List(m *ice.Message, arg ...string) {
|
||||
s.Product.List(m.Options(model.PRODUCT_TYPE, kit.Format(ProductGoods)), arg...)
|
||||
kit.If(s.checkListRole(m, arg...), func() { m.PushAction(s.Market, s.SetShop, s.SetBrand, s.SetQuality, s.Modify, s.Remove) })
|
||||
kit.If(s.IsBoss(m), func() {
|
||||
m.PushAction(s.MarketInsert, s.SetShop, s.SetBrand, s.SetQuality, s.Modify, s.Remove).Action(s.Create)
|
||||
s.Button(m, "")
|
||||
})
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(goods{}) }
|
||||
|
@ -12,17 +12,13 @@ type loan struct {
|
||||
fields string `data:"loan_type,amount,name,info"`
|
||||
create string `name:"create loan_type* amount name info" role:"boss"`
|
||||
modify string `name:"modify name info amount" role:"boss"`
|
||||
list string `name:"list store_uid uid auto" role:"boss"`
|
||||
}
|
||||
|
||||
func (s loan) Create(m *ice.Message, arg ...string) {
|
||||
arg = kit.TransArgKeys(arg, model.LOAN_TYPE, model.TYPE)
|
||||
arg = kit.TransArgKeys(s.transPrice(m, arg...), model.LOAN_TYPE, model.TYPE)
|
||||
s.Value.Create(m, kit.Simple(arg, model.TO_USER_UID, m.Option(model.USER_UID))...)
|
||||
}
|
||||
func (s loan) List(m *ice.Message, arg ...string) {
|
||||
if s.checkListRole(m, arg...) {
|
||||
s.Value.List(m, arg...)
|
||||
}
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(loan{}) }
|
||||
|
||||
|
@ -16,10 +16,11 @@ func (s material) Create(m *ice.Message, arg ...string) {
|
||||
s.Product.Create(m, kit.Simple(model.PRODUCT_TYPE, ProductMaterial, arg)...)
|
||||
}
|
||||
func (s material) List(m *ice.Message, arg ...string) {
|
||||
if s.checkListRole(m, arg...) {
|
||||
s.Product.List(m.Options(model.PRODUCT_TYPE, kit.Format(ProductMaterial)), arg...)
|
||||
m.PushAction(s.SetWarehouse, s.Modify, s.Remove)
|
||||
}
|
||||
s.Product.List(m.Options(model.PRODUCT_TYPE, kit.Format(ProductMaterial)), arg...)
|
||||
kit.If(s.IsBoss(m), func() {
|
||||
m.PushAction(s.SetWarehouse, s.Modify, s.Remove).Action(s.Create)
|
||||
s.Button(m, "")
|
||||
})
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(material{}) }
|
||||
|
@ -11,8 +11,8 @@ const (
|
||||
STATUS = "status"
|
||||
TITLE = "title"
|
||||
CONTENT = "content"
|
||||
AUTH_UID = "auth_uid"
|
||||
USER_UID = "user_uid"
|
||||
USER_ROLE = "user_role"
|
||||
USER_STORE_ROLE = "user_store_role"
|
||||
STORE_UID = "store_uid"
|
||||
STORE_NAME = "store_name"
|
||||
@ -73,6 +73,16 @@ type Warehouse struct {
|
||||
StoreUID string `gorm:"type:char(32);index"`
|
||||
Address string `gorm:"type:varchar(255)"`
|
||||
}
|
||||
type Quality struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
StoreUID string `gorm:"type:char(32);index"`
|
||||
}
|
||||
type Brand struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
StoreUID string `gorm:"type:char(32);index"`
|
||||
}
|
||||
type Product struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
@ -101,9 +111,9 @@ type Order struct {
|
||||
RefundSuccessTime db.Time
|
||||
Name string `gorm:"type:varchar(64)"`
|
||||
Info string
|
||||
Total int `gorm:"default:0"`
|
||||
Amount int `gorm:"default:0"`
|
||||
Status uint8 `gorm:"default:0"`
|
||||
Amount int `gorm:"default:0"`
|
||||
Total int `gorm:"default:0"`
|
||||
}
|
||||
type OrderDetail struct {
|
||||
db.ModelWithUID
|
||||
@ -134,22 +144,12 @@ type Refund struct {
|
||||
|
||||
func init() {
|
||||
db.CmdModels("",
|
||||
&UserStore{}, &Store{}, &Shop{}, &Warehouse{}, &Product{},
|
||||
&UserStore{}, &Store{}, &Shop{}, &Warehouse{}, &Quality{}, &Brand{}, &Product{},
|
||||
&Order{}, &OrderDetail{}, &Payment{}, &Express{}, &Return{}, &Refund{},
|
||||
&Brand{}, &Quality{}, &Expense{}, &Loan{},
|
||||
&Expense{}, &Loan{},
|
||||
)
|
||||
}
|
||||
|
||||
type Brand struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
StoreUID string `gorm:"type:char(32);index"`
|
||||
}
|
||||
type Quality struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
StoreUID string `gorm:"type:char(32);index"`
|
||||
}
|
||||
type Expense struct {
|
||||
db.ModelNameInfo
|
||||
UserUID string `gorm:"type:char(32);index"`
|
||||
|
@ -1,6 +1,8 @@
|
||||
package gongyinglian
|
||||
|
||||
import (
|
||||
"math"
|
||||
|
||||
"shylinux.com/x/ice"
|
||||
"shylinux.com/x/icebergs/base/aaa"
|
||||
"shylinux.com/x/icebergs/base/ctx"
|
||||
@ -13,17 +15,17 @@ type Order struct {
|
||||
Table
|
||||
userStore userStore
|
||||
store store
|
||||
orderDetail orderDetail
|
||||
product Product
|
||||
orderDetail orderDetail
|
||||
models string `data:"order"`
|
||||
sell string `name:"sell name info" role:"boss" help:"出货"`
|
||||
produce string `name:"produce name info" role:"boss" help:"加工"`
|
||||
purchase string `name:"purchase name info" role:"boss" help:"进货"`
|
||||
insert string `name:"insert product_uid*:select count*" role:"boss"`
|
||||
update string `name:"update price* count*" role:"boss"`
|
||||
delete string `name:"delete" role:"boss"`
|
||||
cancel string `name:"cancel" role:"boss"`
|
||||
submit string `name:"submit" role:"boss"`
|
||||
sell string `name:"sell name info" help:"出货" role:"boss,worker"`
|
||||
produce string `name:"produce name info" help:"加工" role:"boss,worker"`
|
||||
purchase string `name:"purchase name info" help:"进货" role:"boss,worker"`
|
||||
insert string `name:"insert product_uid*:select count*" role:"boss,worker"`
|
||||
update string `name:"update count* price*" role:"boss,worker"`
|
||||
delete string `name:"delete" role:"boss,worker"`
|
||||
cancel string `name:"cancel" role:"boss,worker"`
|
||||
submit string `name:"submit" role:"boss,worker"`
|
||||
confirmSell string `name:"confirmSell from_store_uid" role:"void"`
|
||||
confirmProduce string `name:"confirmProduce" role:"void"`
|
||||
confirmPurchase string `name:"confirmPurchase to_store_uid" role:"void"`
|
||||
@ -32,10 +34,11 @@ type Order struct {
|
||||
payment string `name:"payment company_uid* open_id*" role:"void"`
|
||||
express string `name:"express company_uid* open_id*" role:"void"`
|
||||
refund string `name:"refund company_uid* open_id*" role:"void"`
|
||||
confirmPayment string `name:"confirmPayment" role:"void"`
|
||||
confirmExpress string `name:"confirmExpress" role:"void"`
|
||||
confirmReturn string `name:"confirmReturn" role:"void"`
|
||||
confirmRefund string `name:"confirmRefund" role:"void"`
|
||||
// return string `name:"return company_uid* open_id*" role:"void"`
|
||||
confirmPayment string `name:"confirmPayment" role:"void"`
|
||||
confirmExpress string `name:"confirmExpress" role:"void"`
|
||||
confirmReturn string `name:"confirmReturn" role:"void"`
|
||||
confirmRefund string `name:"confirmRefund" role:"void"`
|
||||
}
|
||||
|
||||
func (s Order) Init(m *ice.Message, arg ...string) {
|
||||
@ -44,24 +47,24 @@ func (s Order) Init(m *ice.Message, arg ...string) {
|
||||
s.Table.Init(m, arg...)
|
||||
}
|
||||
func (s Order) Sell(m *ice.Message, arg ...string) {
|
||||
s.Create(m, kit.Simple(arg, model.FROM_STORE_UID, m.Option(model.STORE_UID), model.FROM_USER_UID, m.Option(model.USER_UID))...)
|
||||
s.Table.Insert(m, kit.Simple(arg, model.FROM_STORE_UID, m.Option(model.STORE_UID), model.FROM_USER_UID, m.Option(model.USER_UID))...)
|
||||
m.ProcessRewrite(model.UID, m.Result())
|
||||
}
|
||||
func (s Order) Produce(m *ice.Message, arg ...string) {
|
||||
s.Create(m, kit.Simple(arg,
|
||||
s.Table.Insert(m, kit.Simple(arg,
|
||||
model.FROM_STORE_UID, m.Option(model.STORE_UID), model.FROM_USER_UID, m.Option(model.USER_UID),
|
||||
model.TO_STORE_UID, m.Option(model.STORE_UID), model.TO_USER_UID, m.Option(model.USER_UID),
|
||||
)...)
|
||||
m.ProcessRewrite(model.UID, m.Result())
|
||||
}
|
||||
func (s Order) Purchase(m *ice.Message, arg ...string) {
|
||||
s.Create(m, kit.Simple(arg, model.TO_STORE_UID, m.Option(model.STORE_UID), model.TO_USER_UID, m.Option(model.USER_UID))...)
|
||||
s.Table.Insert(m, kit.Simple(arg, model.TO_STORE_UID, m.Option(model.STORE_UID), model.TO_USER_UID, m.Option(model.USER_UID))...)
|
||||
m.ProcessRewrite(model.UID, m.Result())
|
||||
}
|
||||
func (s Order) List(m *ice.Message, arg ...string) {
|
||||
m.Display("")
|
||||
if len(arg) == 1 {
|
||||
if !s.checkListRole(m, arg...) {
|
||||
if !s.IsBoss(m) && !s.IsWorker(m) {
|
||||
return
|
||||
}
|
||||
switch OrderType(kit.Int(m.Option(model.ORDER_TYPE))) {
|
||||
@ -136,10 +139,10 @@ func (s Order) List(m *ice.Message, arg ...string) {
|
||||
}
|
||||
case OrderSubmit:
|
||||
if user_uid == msg.Append(model.FROM_USER_UID) && msg.Append(model.TO_USER_UID) == "" {
|
||||
m.Echo("请让经销商扫码确认订单")
|
||||
m.Echo("请让买家扫码确认订单")
|
||||
m.EchoQRCode(s.Link(m, arg[0], m.PrefixKey(), arg[1]))
|
||||
} else if user_uid == msg.Append(model.TO_USER_UID) && msg.Append(model.FROM_USER_UID) == "" {
|
||||
m.Echo("请让供货商扫码确认订单")
|
||||
m.Echo("请让卖家扫码确认订单")
|
||||
m.EchoQRCode(s.Link(m, arg[0], m.PrefixKey(), arg[1]))
|
||||
} else if msg.Append(model.FROM_USER_UID) == "" {
|
||||
m.EchoButton(s.ConfirmSell)
|
||||
@ -197,17 +200,17 @@ func (s Order) Amount(m *ice.Message, arg ...string) {
|
||||
}
|
||||
func (s Order) Insert(m *ice.Message, arg ...string) {
|
||||
msg := m.Cmd(s.product, m.Option(model.STORE_UID), m.Option(model.PRODUCT_UID))
|
||||
m.Cmd(s.orderDetail, s.Create, arg, msg.AppendSimple(model.PRICE), model.ORDER_UID, m.Option(model.UID))
|
||||
s.Amount(m)
|
||||
}
|
||||
func (s Order) Delete(m *ice.Message, arg ...string) {
|
||||
m.Cmd(s.orderDetail, s.Delete, model.UID, m.Option(model.ORDER_DETAIL_UID), model.ORDER_UID, m.Option(model.UID))
|
||||
m.Cmd(s.orderDetail, s.Insert, arg, msg.AppendSimple(model.PRICE), model.ORDER_UID, m.Option(model.UID))
|
||||
s.Amount(m)
|
||||
}
|
||||
func (s Order) Update(m *ice.Message, arg ...string) {
|
||||
m.Cmdy(s.orderDetail, s.Update, model.UID, m.Option(model.ORDER_DETAIL_UID), model.ORDER_UID, m.Option(model.UID))
|
||||
s.Amount(m)
|
||||
}
|
||||
func (s Order) Delete(m *ice.Message, arg ...string) {
|
||||
m.Cmd(s.orderDetail, s.Delete, model.UID, m.Option(model.ORDER_DETAIL_UID), model.ORDER_UID, m.Option(model.UID))
|
||||
s.Amount(m)
|
||||
}
|
||||
func (s Order) Cancel(m *ice.Message, arg ...string) {
|
||||
s.Table.Update(m, kit.Dict(model.STATUS, OrderCancel), m.OptionSimple(model.UID)...)
|
||||
}
|
||||
@ -236,9 +239,9 @@ func (s Order) ConfirmPurchase(m *ice.Message, arg ...string) {
|
||||
}
|
||||
func (s Order) Again(m *ice.Message, arg ...string) {
|
||||
s.changeStatusFrom(m, OrderDeal, "", func(msg *ice.Message) {
|
||||
s.Create(m, kit.Simple(model.STATUS, OrderConfirm, msg.AppendSimple(model.FROM_STORE_UID, model.FROM_USER_UID, model.TO_STORE_UID, model.TO_USER_UID))...)
|
||||
s.Table.Insert(m, kit.Simple(model.STATUS, OrderConfirm, msg.AppendSimple(model.FROM_STORE_UID, model.FROM_USER_UID, model.TO_STORE_UID, model.TO_USER_UID))...)
|
||||
m.Cmd(s.orderDetail, m.Option(model.STORE_UID), m.Option(model.UID)).Table(func(detail ice.Maps) {
|
||||
m.Cmd(s.orderDetail, s.Create, model.STORE_UID, detail[model.STORE_UID], model.ORDER_UID, m.Result(),
|
||||
m.Cmd(s.orderDetail, s.Insert, model.STORE_UID, detail[model.STORE_UID], model.ORDER_UID, m.Result(),
|
||||
model.PRODUCT_UID, detail[model.PRODUCT_UID], model.PRICE, detail[model.PRICE], model.COUNT, detail[model.COUNT],
|
||||
)
|
||||
})
|
||||
@ -254,6 +257,12 @@ func (s Order) Process(m *ice.Message, arg ...string) {
|
||||
}
|
||||
m.Cmd(s.product, m.Option(model.STORE_UID), detail[model.PRODUCT_UID]).Table(func(product ice.Maps) {
|
||||
count, stock := kit.Int(detail[model.COUNT]), kit.Int(product[model.STOCK])
|
||||
switch ProductType(kit.Int(product[model.PRODUCT_TYPE])) {
|
||||
case ProductGoods:
|
||||
count = kit.Int(math.Abs(float64(count)))
|
||||
case ProductMaterial:
|
||||
count = -kit.Int(math.Abs(float64(count)))
|
||||
}
|
||||
if m.Warn(count < 0 && -count > stock, product[model.NAME], "库存不足") {
|
||||
return
|
||||
}
|
||||
@ -285,10 +294,9 @@ func (s Order) Payment(m *ice.Message, arg ...string) {
|
||||
return
|
||||
}
|
||||
}
|
||||
m.Cmdy(payment{}, s.Create, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, PaymentSuccess)
|
||||
m.Cmdy(payment{}, s.Insert, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, PaymentSuccess)
|
||||
s.Table.Update(m, kit.Dict(model.PAYMENT_STATUS, PaymentSuccess, model.PAYMENT_SUCCESS_TIME, m.Time()), m.OptionSimple(model.UID)...)
|
||||
m.Option(model.FROM_USER_UID, msg.Option(model.FROM_USER_UID))
|
||||
Portal{}.DashboardUpdate(m)
|
||||
})
|
||||
s.sendTemplate(m, model.FROM_USER_UID, m.Trans("order payment", "订单已付款"))
|
||||
}
|
||||
@ -308,7 +316,7 @@ func (s Order) Express(m *ice.Message, arg ...string) {
|
||||
if m.WarnNotValid(ExpressStatus(kit.Int(msg.Append(model.EXPRESS_STATUS))) != ExpressUnknown) {
|
||||
return
|
||||
}
|
||||
m.Cmdy(express{}, s.Create, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, ExpressRecv)
|
||||
m.Cmdy(express{}, s.Insert, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, ExpressRecv)
|
||||
s.Table.Update(m, kit.Dict(model.EXPRESS_STATUS, ExpressRecv), m.OptionSimple(model.UID)...)
|
||||
m.Option(model.TO_USER_UID, msg.Option(model.TO_USER_UID))
|
||||
})
|
||||
@ -324,8 +332,8 @@ func (s Order) ConfirmExpress(m *ice.Message, arg ...string) {
|
||||
}
|
||||
s.Table.Update(m, kit.Dict(model.STATUS, OrderDeal, model.EXPRESS_STATUS, ExpressConfirm, model.EXPRESS_RECV_TIME, m.Time()), m.OptionSimple(model.UID)...)
|
||||
m.Option(model.FROM_USER_UID, msg.Option(model.FROM_USER_UID))
|
||||
Portal{}.DashboardUpdate(m)
|
||||
})
|
||||
s.DashboardUpdate(m)
|
||||
s.sendTemplate(m, model.FROM_USER_UID, m.Trans("order confirm express", "订单已确认收货"))
|
||||
}
|
||||
func (s Order) Return(m *ice.Message, arg ...string) {
|
||||
@ -336,7 +344,7 @@ func (s Order) Return(m *ice.Message, arg ...string) {
|
||||
if m.WarnNotValid(ReturnStatus(kit.Int(msg.Append(model.RETURN_STATUS))) != ReturnUnknown) {
|
||||
return
|
||||
}
|
||||
m.Cmdy(Return{}, s.Create, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, ReturnRecv)
|
||||
m.Cmdy(Return{}, s.Insert, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, ReturnRecv)
|
||||
s.Table.Update(m, kit.Dict(model.RETURN_STATUS, ReturnRecv, model.RETURN_RECV_TIME, m.Time()), m.OptionSimple(model.UID)...)
|
||||
m.Option(model.FROM_USER_UID, msg.Option(model.FROM_USER_UID))
|
||||
})
|
||||
@ -356,6 +364,7 @@ func (s Order) ConfirmReturn(m *ice.Message, arg ...string) {
|
||||
s.ReturnProduct(m)
|
||||
s.Table.Update(m, kit.Dict(model.RETURN_STATUS, ReturnConfirm), m.OptionSimple(model.UID)...)
|
||||
})
|
||||
s.DashboardUpdate(m)
|
||||
}
|
||||
func (s Order) Refund(m *ice.Message, arg ...string) {
|
||||
s.changeStatusFrom(m, -1, model.FROM_USER_UID, func(msg *ice.Message) {
|
||||
@ -365,7 +374,7 @@ func (s Order) Refund(m *ice.Message, arg ...string) {
|
||||
if m.WarnNotValid(RefundStatus(kit.Int(msg.Append(model.REFUND_STATUS))) != RefundUnknown) {
|
||||
return
|
||||
}
|
||||
m.Cmdy(refund{}, s.Create, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, RefundSuccess)
|
||||
m.Cmdy(refund{}, s.Insert, model.ORDER_UID, m.Option(model.UID), m.OptionSimple(model.COMPANY_UID, model.OPEN_ID), model.STATUS, RefundSuccess)
|
||||
s.Table.Update(m, kit.Dict(model.REFUND_STATUS, RefundSuccess, model.REFUND_SUCCESS_TIME, m.Time()), m.OptionSimple(model.UID)...)
|
||||
m.Option(model.TO_USER_UID, msg.Option(model.TO_USER_UID))
|
||||
})
|
||||
@ -393,7 +402,6 @@ func (s Order) CheckRole(m *ice.Message, arg ...string) {
|
||||
func init() { ice.TeamCtxCmd(Order{}) }
|
||||
|
||||
func (s Order) changeStatusFrom(m *ice.Message, from OrderStatus, which string, cb func(*ice.Message)) {
|
||||
defer m.ToastProcess()()
|
||||
s.Transaction(m, func() {
|
||||
msg := s.SelectForUpdate(m.Spawn(), m.OptionSimple(model.UID)...)
|
||||
if from != -1 && m.WarnNotValid(OrderStatus(kit.Int(msg.Append(model.STATUS))) != from) {
|
||||
|
@ -1,8 +1,8 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.name||value.user_name||"待确认", can.onimport.textView(can, value, "order_type", mdb.TYPE)]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value, "order_status", mdb.STATUS)]},
|
||||
{view: html.TITLE, list: [value.name||value.user_name||"待确认", can.onimport.textView(can, value, "order_type")]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value)]},
|
||||
{view: html.STATUS, list: ["数量:", value.total, "件", "总额:", value.amount, "元"]},
|
||||
value.payment_success_time && {view: html.STATUS, list: ["收款时间:", can.base.TimeTrim(value.payment_success_time)]},
|
||||
value.express_recv_time && {view: html.STATUS, list: ["收货时间:", can.base.TimeTrim(value.express_recv_time)]},
|
||||
|
@ -21,7 +21,7 @@ func (s orderDetail) Amount(m *ice.Message, arg ...string) {
|
||||
s.Select(m, model.ORDER_UID, arg[0])
|
||||
}
|
||||
func (s orderDetail) List(m *ice.Message, arg ...string) {
|
||||
if !s.checkOrderRole(m.Spawn(), arg...) {
|
||||
if !s.checkOrderRole(m, arg[0], arg[1]) {
|
||||
return
|
||||
}
|
||||
m.Display("")
|
||||
|
@ -1,8 +1,7 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
msg.Option("_share_title", can.Option("uid").slice(0, 6))
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.name, can.onimport.textView(can, value, "product_type", mdb.TYPE)]},
|
||||
{view: html.TITLE, list: [value.name, can.onimport.textView(can, value, "product_type")]},
|
||||
{view: html.STATUS, list: ["单价: ", value.price, " 元", "数量: ", value.count, " ", value.unit]},
|
||||
{view: html.OUTPUT, list: [value.info]},
|
||||
] }, function(event) {})
|
||||
|
@ -1,9 +1,9 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.user_name, can.onimport.textView(can, value, "payment_status", mdb.STATUS)]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name, ": ", value.open_id]},
|
||||
{view: html.TITLE, list: [value.user_name]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name+":", value.open_id]},
|
||||
{view: html.STATUS, list: ["订单:", value.order_uid.slice(0, 6), "金额:", value.amount||"0", "数量:", value.total||"0"]},
|
||||
] })
|
||||
},
|
||||
|
@ -13,11 +13,11 @@ type Portal struct {
|
||||
guanlixitong.Portal
|
||||
product Product
|
||||
order Order
|
||||
placeCreate string `name:"placeCreate city_name* company_name* store_type*:select store_name*" role:"void"`
|
||||
placeCreate string `name:"placeCreate city_name* company_name* store_name* store_type*:select" role:"void"`
|
||||
}
|
||||
|
||||
func (s Portal) AfterPlaceAuth(m *ice.Message, arg ...string) {
|
||||
s.DashboardCreate(m, "")
|
||||
defer s.DashboardCreate(m, "")()
|
||||
s.DashboardInsert(m, "1", "订单总额", s.order, "SUM(amount) / 100.0", model.FROM_STORE_UID, m.Option(model.STORE_UID), model.STATUS, kit.Format(OrderDeal))
|
||||
s.DashboardInsert(m, "2", "订单数量", s.order, "", model.FROM_STORE_UID, m.Option(model.STORE_UID), model.STATUS, kit.Format(OrderDeal))
|
||||
s.DashboardInsert(m, "3", "库存数量", s.product, "SUM(stock)")
|
||||
|
@ -1,11 +1,11 @@
|
||||
{
|
||||
"portal": "供应链",
|
||||
"goods": "商品", "sell": "出货", "purchase": "进货", "expense": "开支",
|
||||
"payment": "付款", "express": "寄货", "return": "退贷", "refund": "退款",
|
||||
"process": "生产", "again": "再来一单",
|
||||
"material": "原材", "produce": "加工", "quality": "质检", "brand": "贴牌",
|
||||
"product": "货物", "order": "订单", "shop": "店铺", "warehouse": "仓库",
|
||||
"member": "生意伙伴", "loan": "借贷外债",
|
||||
"portal": "供应链", "member": "生意伙伴",
|
||||
"goods": "商品", "sell": "出货", "produce": "加工", "purchase": "进货", "material": "原材",
|
||||
"payment": "付款", "express": "寄货", "expense": "开支", "return": "退贷", "refund": "退款",
|
||||
"shop": "店铺", "warehouse": "仓库", "quality": "质检", "brand": "贴牌", "loan": "借贷外债",
|
||||
"product": "货物", "order": "订单",
|
||||
"again": "再来一单",
|
||||
"process": "加工",
|
||||
"confirmSell": "确认出货",
|
||||
"confirmProduce": "确认加工",
|
||||
"confirmPurchase": "确认进货",
|
||||
@ -20,40 +20,39 @@
|
||||
"icons": {
|
||||
"goods": "https://img.icons8.com/officel/80/product.png",
|
||||
"sell": "https://img.icons8.com/officel/80/handle-with-care.png",
|
||||
"produce": "https://img.icons8.com/officel/80/cnc-machine.png",
|
||||
"purchase": "https://img.icons8.com/officel/80/paid.png",
|
||||
"expense": "https://img.icons8.com/officel/80/cash-in-hand.png",
|
||||
"material": "https://img.icons8.com/officel/80/wood.png",
|
||||
"payment": "https://img.icons8.com/officel/80/fund-accounting.png",
|
||||
"express": "https://img.icons8.com/officel/80/in-transit.png",
|
||||
"expense": "https://img.icons8.com/officel/80/cash-in-hand.png",
|
||||
"return": "https://img.icons8.com/officel/80/deliver-food.png",
|
||||
"refund": "https://img.icons8.com/officel/80/refund-2.png",
|
||||
"material": "https://img.icons8.com/officel/80/wood.png",
|
||||
"produce": "https://img.icons8.com/officel/80/cnc-machine.png",
|
||||
"quality": "https://img.icons8.com/officel/80/test-partial-passed.png",
|
||||
"brand": "https://img.icons8.com/officel/80/add-tag.png",
|
||||
"product": "https://img.icons8.com/officel/80/warehouse.png",
|
||||
"order": "https://img.icons8.com/officel/80/receipt.png",
|
||||
"shop": "https://img.icons8.com/officel/80/shop.png",
|
||||
"warehouse": "https://img.icons8.com/officel/80/garage-closed.png",
|
||||
"loan": "https://img.icons8.com/officel/80/bank-building.png"
|
||||
"quality": "https://img.icons8.com/officel/80/test-partial-passed.png",
|
||||
"brand": "https://img.icons8.com/officel/80/add-tag.png",
|
||||
"loan": "https://img.icons8.com/officel/80/bank-building.png",
|
||||
"product": "https://img.icons8.com/officel/80/warehouse.png",
|
||||
"order": "https://img.icons8.com/officel/80/receipt.png"
|
||||
},
|
||||
"input": {
|
||||
"My Store": "我的生意",
|
||||
"user_store_role": "用户角色",
|
||||
"store_uid": "生意",
|
||||
"store_type": "生意类型",
|
||||
"store_name": "生意名称",
|
||||
"store_type": "生意类型",
|
||||
"shop_uid": "店铺",
|
||||
"shop_name": "店铺名称",
|
||||
"warehouse_uid": "仓库",
|
||||
"warehouse_name": "仓库名称",
|
||||
"quality_name": "质检名称",
|
||||
"brand_name": "品牌名称",
|
||||
"order_type": "订单类型",
|
||||
"product_uid": "产品",
|
||||
"product_type": "产品类型",
|
||||
"company_uid": "公司",
|
||||
"to_store_uid": "收货店铺",
|
||||
"order_type": "订单类型",
|
||||
"from_store_uid":"出货店铺",
|
||||
"to_store_uid": "收货店铺",
|
||||
"payment_status": "付款状态",
|
||||
"express_status": "快递状态",
|
||||
"return_status": "退货状态",
|
||||
@ -72,7 +71,8 @@
|
||||
"boss": "老板",
|
||||
"worker": "员工",
|
||||
"vendor": "供货商",
|
||||
"custom": "经销商",
|
||||
"channel": "经销商",
|
||||
"custom": "顾客",
|
||||
"style": {
|
||||
"creator": "danger",
|
||||
"boss": "danger"
|
||||
@ -80,9 +80,11 @@
|
||||
},
|
||||
"store_type": {
|
||||
"shop": "店铺",
|
||||
"channel": "渠道",
|
||||
"factory": "工厂",
|
||||
"icons": {
|
||||
"shop": "https://img.icons8.com/officel/80/shop.png",
|
||||
"channel": "https://img.icons8.com/officel/80/sales-channels.png",
|
||||
"factory": "https://img.icons8.com/officel/80/cnc-machine.png"
|
||||
}
|
||||
},
|
||||
@ -122,25 +124,25 @@
|
||||
"payment_status": {
|
||||
"create": "🕑 已发起付款",
|
||||
"failure": "❌ 付款失败",
|
||||
"success": "🕑 待确认收款",
|
||||
"success": "✅ 已付款",
|
||||
"confirm": "✅ 已确认收款"
|
||||
},
|
||||
"express_status": {
|
||||
"create": "🕑 已发起寄货",
|
||||
"send": "🕑 已寄货",
|
||||
"recv": "🕑 待确认收货",
|
||||
"recv": "✅ 已收货",
|
||||
"confirm": "✅ 已确认收货"
|
||||
},
|
||||
"return_status": {
|
||||
"create": "🕑 已发起退货",
|
||||
"send": "🕑 已寄货",
|
||||
"recv": "🕑 待确认退货",
|
||||
"recv": "✅ 已收货",
|
||||
"confirm": "✅ 已确认退货"
|
||||
},
|
||||
"refund_status": {
|
||||
"create": "🕑 已发起退款",
|
||||
"failure": "❌ 退款失败",
|
||||
"success": "🕑 待确认收款",
|
||||
"success": "✅ 已退款",
|
||||
"confirm": "✅ 已确认收款"
|
||||
},
|
||||
"expense_type": {
|
||||
|
@ -1,38 +0,0 @@
|
||||
chapter "供应链"
|
||||
field web.code.mysql.client
|
||||
field web.code.mysql.query args `mysql gongyinglian`
|
||||
field web.code.db.models
|
||||
|
||||
order `
|
||||
userStore.go
|
||||
store.go
|
||||
product.go
|
||||
product.js
|
||||
order.go
|
||||
order.js
|
||||
orderDetail.go
|
||||
orderDetail.js
|
||||
payment.go
|
||||
express.go
|
||||
return.go
|
||||
refund.go
|
||||
|
||||
model
|
||||
common.go
|
||||
portal.go
|
||||
portal.json
|
||||
portal.shy
|
||||
|
||||
goods.go
|
||||
sell.go
|
||||
purchase.go
|
||||
material.go
|
||||
produce.go
|
||||
quality.go
|
||||
brand.go
|
||||
|
||||
shop.go
|
||||
warehouse.go
|
||||
expense.go
|
||||
loan.go
|
||||
`
|
@ -16,6 +16,7 @@ type Product struct {
|
||||
models string `data:"product"`
|
||||
create string `name:"create product_type*:select name* info price stock unit" role:"boss"`
|
||||
modify string `name:"modify name* info price stock unit" role:"boss"`
|
||||
remove string `name:"remove" role:"boss"`
|
||||
setShop string `name:"setShop shop_uid*" role:"boss"`
|
||||
setWarehouse string `name:"setWarehouse warehouse_uid*" role:"boss"`
|
||||
setQuality string `name:"setQuality quality_uid*" role:"boss"`
|
||||
@ -23,11 +24,10 @@ type Product struct {
|
||||
}
|
||||
|
||||
func (s Product) Create(m *ice.Message, arg ...string) {
|
||||
arg = kit.TransArgKeys(arg, model.PRODUCT_TYPE, model.TYPE)
|
||||
s.Value.Create(m, arg...)
|
||||
s.Value.Create(m, kit.TransArgKeys(arg, model.PRODUCT_TYPE, model.TYPE)...)
|
||||
}
|
||||
func (s Product) List(m *ice.Message, arg ...string) {
|
||||
if m.Option(model.PRODUCT_TYPE) != kit.Format(ProductGoods) && !s.checkListRole(m, arg...) {
|
||||
if m.Option(model.PRODUCT_TYPE) != kit.Format(ProductGoods) && s.IsVisitor(m) {
|
||||
return
|
||||
}
|
||||
if len(arg) == 0 {
|
||||
@ -45,13 +45,12 @@ func (s Product) List(m *ice.Message, arg ...string) {
|
||||
kit.If(m.Option(model.PRODUCT_TYPE), func(p string) { args = append(args, s.Key(s, model.TYPE), p) })
|
||||
if len(arg) == 1 {
|
||||
s.Select(m, args...)
|
||||
s.Button(m, "")
|
||||
} else if len(arg) == 2 {
|
||||
s.SelectDetail(m, append(args, s.Key(s, model.UID), arg[1])...)
|
||||
} else {
|
||||
return
|
||||
}
|
||||
m.PushAction(s.Modify, s.Remove).Display("")
|
||||
m.Action().Display("")
|
||||
}
|
||||
func (s Product) SetShop(m *ice.Message, arg ...string) { s.Value.Modify(m, arg...) }
|
||||
func (s Product) SetWarehouse(m *ice.Message, arg ...string) { s.Value.Modify(m, arg...) }
|
||||
|
@ -1,7 +1,7 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.name, can.onimport.textView(can, value, "product_type", mdb.TYPE)]},
|
||||
{view: html.TITLE, list: [value.name, can.onimport.textView(can, value, "product_type")]},
|
||||
{view: html.STATUS, list: ["单价:", value.price, "元", "库存:", value.stock, value.unit, value.shop_name||"", value.warehouse_name||""]},
|
||||
{view: html.OUTPUT, list: [value.info]},
|
||||
] })
|
||||
|
@ -1,7 +1,15 @@
|
||||
package gongyinglian
|
||||
|
||||
import "shylinux.com/x/ice"
|
||||
import (
|
||||
"shylinux.com/x/ice"
|
||||
kit "shylinux.com/x/toolkits"
|
||||
)
|
||||
|
||||
type quality struct{ Value }
|
||||
|
||||
func (s quality) List(m *ice.Message, arg ...string) {
|
||||
s.Value.List(m, arg...)
|
||||
kit.If(!s.IsBoss(m), func() { m.PushAction().Action().SetResult() })
|
||||
}
|
||||
|
||||
func init() { ice.TeamCtxCmd(quality{}) }
|
||||
|
@ -1,9 +1,9 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.user_name, can.onimport.textView(can, value, "refund_status", mdb.STATUS)]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name, ": ", value.open_id]},
|
||||
{view: html.TITLE, list: [value.user_name]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name+":", value.open_id]},
|
||||
{view: html.STATUS, list: ["订单:", value.order_uid.slice(0, 6), "金额:", value.amount||"0", "数量:", value.total||"0"]},
|
||||
] })
|
||||
},
|
||||
|
@ -1,8 +1,8 @@
|
||||
Volcanos(chat.ONIMPORT, {
|
||||
_init: function(can, msg) {
|
||||
can.onimport.myView(can, msg, function(value) { return [
|
||||
{view: html.TITLE, list: [value.user_name, can.onimport.textView(can, value, "return_status", mdb.STATUS)]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value)]},
|
||||
{view: html.TITLE, list: [value.user_name]},
|
||||
{view: html.STATUS, list: [value.uid.slice(0, 6), can.onimport.timeView(can, value), can.onimport.textView(can, value)]},
|
||||
{view: html.STATUS, list: [value.company_name+":", value.open_id]},
|
||||
{view: html.STATUS, list: ["订单:", value.order_uid.slice(0, 6), "金额:", value.amount||"0", "数量:", value.total||"0"]},
|
||||
] })
|
||||
|
@ -1,14 +1,20 @@
|
||||
package gongyinglian
|
||||
|
||||
import "shylinux.com/x/ice"
|
||||
import (
|
||||
"shylinux.com/x/ice"
|
||||
kit "shylinux.com/x/toolkits"
|
||||
)
|
||||
|
||||
type Shop struct {
|
||||
Value
|
||||
fields string `data:"name,address"`
|
||||
fields string `data:"name,address,user_uid"`
|
||||
create string `name:"create name* address" role:"boss"`
|
||||
modify string `name:"modify name* address" role:"boss"`
|
||||
remove string `name:"remove" role:"boss"`
|
||||
}
|
||||
|
||||
func (s Shop) List(m *ice.Message, arg ...string) { s.ValueList(m, arg) }
|
||||
|
||||
func (s Shop) List(m *ice.Message, arg ...string) {
|
||||
s.Value.List(m, arg...)
|
||||
kit.If(!s.IsBoss(m), func() { m.PushAction().Action().SetResult() })
|
||||
}
|
||||
func init() { ice.TeamCtxCmd(Shop{}) }
|
||||
|
@ -18,11 +18,13 @@ type StoreType int
|
||||
|
||||
const (
|
||||
StoreShop StoreType = iota
|
||||
StoreChannel
|
||||
StoreFactory
|
||||
)
|
||||
|
||||
var StoreTypeList = map[StoreType]string{
|
||||
StoreShop: "shop",
|
||||
StoreChannel: "channel",
|
||||
StoreFactory: "factory",
|
||||
}
|
||||
|
||||
|
@ -14,6 +14,7 @@ const (
|
||||
UserStoreBoss
|
||||
UserStoreWorker
|
||||
UserStoreVendor
|
||||
UserStoreChannel
|
||||
UserStoreCustom
|
||||
)
|
||||
|
||||
@ -23,6 +24,7 @@ var UserStoreRoleList = map[UserStoreRole]string{
|
||||
UserStoreBoss: "boss",
|
||||
UserStoreWorker: "worker",
|
||||
UserStoreVendor: "vendor",
|
||||
UserStoreChannel: "channel",
|
||||
UserStoreCustom: "custom",
|
||||
}
|
||||
|
||||
|
@ -4,13 +4,11 @@ import "shylinux.com/x/ice"
|
||||
|
||||
type promotion struct {
|
||||
Table
|
||||
fields string `data:"title,content"`
|
||||
fields string `data:"title,content,user_uid"`
|
||||
create string `name:"create title* content*" role:"leader"`
|
||||
remove string `name:"remove" role:"leader"`
|
||||
}
|
||||
|
||||
func (s promotion) Create(m *ice.Message, arg ...string) { s.ValueCreate(m, arg...) }
|
||||
func (s promotion) Remove(m *ice.Message, arg ...string) { s.ValueRemove(m, arg...) }
|
||||
func (s promotion) List(m *ice.Message, arg ...string) { s.ValueList(m, arg).Display("") }
|
||||
func (s promotion) List(m *ice.Message, arg ...string) { s.ValueList(m, arg).Display("") }
|
||||
|
||||
func init() { ice.TeamCtxCmd(promotion{}) }
|
||||
|
@ -4,13 +4,11 @@ import "shylinux.com/x/ice"
|
||||
|
||||
type investment struct {
|
||||
Table
|
||||
fields string `data:"title,content"`
|
||||
fields string `data:"title,content,user_uid"`
|
||||
create string `name:"create title* content*" role:"leader"`
|
||||
remove string `name:"remove" role:"leader"`
|
||||
}
|
||||
|
||||
func (s investment) Create(m *ice.Message, arg ...string) { s.ValueCreate(m, arg...) }
|
||||
func (s investment) Remove(m *ice.Message, arg ...string) { s.ValueRemove(m, arg...) }
|
||||
func (s investment) List(m *ice.Message, arg ...string) { s.ValueList(m, arg).Display("") }
|
||||
func (s investment) List(m *ice.Message, arg ...string) { s.ValueList(m, arg).Display("") }
|
||||
|
||||
func init() { ice.TeamCtxCmd(investment{}) }
|
||||
|
Loading…
x
Reference in New Issue
Block a user