135 lines
4.3 KiB
Go
135 lines
4.3 KiB
Go
package dao
|
|
|
|
import (
|
|
"git.rosy.net.cn/baseapi/utils"
|
|
"git.rosy.net.cn/jx-callback/business/model"
|
|
)
|
|
|
|
type StoreDetail struct {
|
|
model.Store
|
|
|
|
VendorStoreID string `orm:"column(vendor_store_id);size(48)" json:"vendorStoreID"`
|
|
VendorStatus int `json:"vendor_status"` // 取值同Store.Status
|
|
DeliveryFee int `json:"deliveryFee"`
|
|
SyncStatus int8 `orm:"default(2)" json:"syncStatus"`
|
|
|
|
PricePercentage int16 `orm:"default(100)" json:"pricePercentage"` // todo 厂商价格相对于本地价格的百分比,这个字段的修改会比较特殊,因为可能需要刷新厂商价格
|
|
AutoPickup int8 `orm:"default(1)" json:"autoPickup"` // 是否自动拣货
|
|
DeliveryType int8 `orm:"default(0)" json:"deliveryType"` // 配送类型
|
|
DeliveryCompetition int8 `orm:"default(1)" json:"deliveryCompetition"` // 是否支持配送竞争
|
|
IsSync int8 `orm:"default(1)" json:"isSync"` // 是否同步
|
|
|
|
model.Place // district info
|
|
}
|
|
|
|
type StoreDetail2 struct {
|
|
model.Store
|
|
VendorStoreID string `orm:"column(vendor_store_id)`
|
|
DistrictName string
|
|
CityName string
|
|
}
|
|
|
|
func GetStoreDetail(db *DaoDB, storeID, vendorID int) (storeDetail *StoreDetail, err error) {
|
|
sql := `
|
|
SELECT t1.*,
|
|
t2.vendor_store_id, t2.status vendor_status, t2.delivery_fee, t2.sync_status,
|
|
t2.price_percentage, t2.auto_pickup, t2.delivery_type, t2.delivery_competition, t2.is_sync,
|
|
district.code, district.name, district.parent_code, district.level, district.tel_code, district.jd_code, district.ebai_code, district.enabled, district.mtps_price
|
|
FROM store t1
|
|
JOIN store_map t2 ON t1.id = t2.store_id AND t2.vendor_id = ? AND t2.deleted_at = ?
|
|
LEFT JOIN place district ON t1.district_code = district.code
|
|
WHERE t1.id = ? AND t1.deleted_at = ?
|
|
`
|
|
storeDetail = &StoreDetail{}
|
|
if err = GetRow(db, storeDetail, sql, vendorID, utils.DefaultTimeValue, storeID, utils.DefaultTimeValue); err == nil {
|
|
return storeDetail, nil
|
|
}
|
|
return nil, err
|
|
}
|
|
|
|
func GetPossibleStoresByPlaceName(db *DaoDB, cityName, provinceName string) (storeList []*StoreDetail2, err error) {
|
|
sqlList := []string{
|
|
`
|
|
SELECT t1.*, t5.vendor_store_id
|
|
FROM store t1
|
|
JOIN place t2 ON t2.code = t1.city_code AND t2.name = ?
|
|
LEFT JOIN store_map t5 ON t1.id = t5.store_id AND t5.vendor_id = ? AND t5.deleted_at = ?
|
|
WHERE t1.status = ?
|
|
`,
|
|
`
|
|
SELECT t1.*, t5.vendor_store_id
|
|
FROM store t1
|
|
JOIN place t2 ON t2.code = t1.city_code
|
|
JOIN place t3 ON t3.code = t2.parent_code AND t3.name = ?
|
|
LEFT JOIN store_map t5 ON t1.id = t5.store_id AND t5.vendor_id = ? AND t5.deleted_at = ?
|
|
WHERE t1.status = ?
|
|
`,
|
|
`
|
|
SELECT t1.*, t5.vendor_store_id
|
|
FROM store t1
|
|
LEFT JOIN store_map t5 ON t1.id = t5.store_id AND t5.vendor_id = ? AND t5.deleted_at = ?
|
|
WHERE t1.status = ?
|
|
`,
|
|
}
|
|
sqlParamsList := [][]interface{}{
|
|
[]interface{}{
|
|
cityName,
|
|
model.VendorIDWSC,
|
|
utils.DefaultTimeValue,
|
|
model.StoreStatusOpened,
|
|
},
|
|
[]interface{}{
|
|
provinceName,
|
|
model.VendorIDWSC,
|
|
utils.DefaultTimeValue,
|
|
model.StoreStatusOpened,
|
|
},
|
|
[]interface{}{
|
|
model.VendorIDWSC,
|
|
utils.DefaultTimeValue,
|
|
model.StoreStatusOpened,
|
|
},
|
|
}
|
|
for k := range sqlList {
|
|
if err = GetRows(db, &storeList, sqlList[k], sqlParamsList[k]); err != nil {
|
|
return nil, err
|
|
}
|
|
if len(storeList) > 0 {
|
|
return storeList, nil
|
|
}
|
|
}
|
|
// 正常是不应该达到这里的
|
|
return storeList, err
|
|
}
|
|
|
|
// 这个返回的地点信息是城市
|
|
func GetMissingDadaStores(db *DaoDB, storeID int) (storeList []*StoreDetail2, err error) {
|
|
sql := `
|
|
SELECT t1.*,
|
|
t2.vendor_store_id,
|
|
city.name city_name, district.name district_name
|
|
FROM store t1
|
|
JOIN store_map t2 ON t1.id = t2.store_id AND t2.vendor_id = ? AND t2.deleted_at = ?
|
|
JOIN place city ON city.code = t1.city_code
|
|
JOIN place district ON district.code = t1.district_code
|
|
LEFT JOIN store_courier_map t3 ON t3.store_id = t1.id AND t3.vendor_id = ? AND t3.deleted_at = ?
|
|
WHERE t1.deleted_at = ? AND t1.status <> ? AND t3.id IS NULL
|
|
`
|
|
sqlParams := []interface{}{
|
|
model.VendorIDJD,
|
|
utils.DefaultTimeValue,
|
|
model.VendorIDDada,
|
|
utils.DefaultTimeValue,
|
|
utils.DefaultTimeValue,
|
|
model.StoreStatusDisabled,
|
|
}
|
|
if storeID != 0 {
|
|
sql += " AND t1.id = ?"
|
|
sqlParams = append(sqlParams, storeID)
|
|
}
|
|
if err = GetRows(db, &storeList, sql, sqlParams...); err == nil {
|
|
return storeList, nil
|
|
}
|
|
return nil, err
|
|
}
|