Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Z
zhichan
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
蒋勇
zhichan
Commits
86694369
Commit
86694369
authored
Jun 21, 2020
by
王勇飞
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'center-manage' of gitlab.gongsibao.com:jiangyong/zhichan into center-manage
parents
9f42d5de
29b8d137
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
236 additions
and
13 deletions
+236
-13
center-manage/app/base/api/impl/auth/accessAuth.js
+2
-2
center-manage/app/base/db/models/auth/user.js
+4
-0
center-manage/app/base/db/models/product/product.js
+12
-0
center-manage/app/base/db/models/product/xproduct.js
+75
-0
center-manage/app/base/service/impl/auth/userSve.js
+29
-10
center-manage/app/base/service/impl/product/productSve.js
+1
-1
center-manage/app/base/service/impl/product/xproductSve.js
+113
-0
No files found.
center-manage/app/base/api/impl/auth/accessAuth.js
View file @
86694369
...
...
@@ -26,11 +26,11 @@ class AccessAuthAPI extends APIBase {
}
async
getBizUserForBizChance
(
p
,
q
,
req
){
let
s
=
await
this
.
userSve
.
getBizUserForBizChance
(
p
.
clientMobile
,
p
.
spName
,
p
.
productCatName
)
let
s
=
await
this
.
userSve
.
getBizUserForBizChance
(
p
.
clientMobile
,
p
.
spName
,
p
.
productCatName
,
p
.
regionName
)
return
system
.
getResult
(
s
)
}
async
getBizUserForDelivery
(
p
,
q
,
req
){
let
s
=
await
this
.
userSve
.
getBizUserForDelivery
(
p
.
clientMobile
,
p
.
spName
,
p
.
productCatName
,
p
.
skucode
)
let
s
=
await
this
.
userSve
.
getBizUserForDelivery
(
p
.
clientMobile
,
p
.
spName
,
p
.
productCatName
,
p
.
skucode
,,
p
.
regionName
)
return
system
.
getResult
(
s
)
}
classDesc
()
{
...
...
center-manage/app/base/db/models/auth/user.js
View file @
86694369
...
...
@@ -52,6 +52,10 @@ module.exports = (db, DataTypes) => {
opath
:
DataTypes
.
STRING
,
//作业务时,需要在业务表冗余当前处理人的opath
ptags
:
DataTypes
.
STRING
,
//权限标签,逗号分隔,可以按照标签查看opath中含有标签的数据
skilltags
:
DataTypes
.
STRING
,
// 技能标签
regiontags
:{
type
:
DataTypes
.
STRING
,
allowNull
:
true
,
}
// 区域标签
},{
paranoid
:
true
,
//假的删除
underscored
:
true
,
...
...
center-manage/app/base/db/models/product/product.js
View file @
86694369
...
...
@@ -4,6 +4,18 @@ const appconfig=system.getSysConfig();
module
.
exports
=
(
db
,
DataTypes
)
=>
{
//定价类型
return
db
.
define
(
"product"
,
{
sptags
:{
//交付商标签
type
:
DataTypes
.
STRING
,
allowNull
:
true
,
},
channeltags
:{
//渠道标签
type
:
DataTypes
.
STRING
,
allowNull
:
true
,
},
industrytags
:{
//行业标签
type
:
DataTypes
.
STRING
,
allowNull
:
true
,
},
code
:{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
...
...
center-manage/app/base/db/models/product/xproduct.js
0 → 100644
View file @
86694369
const
system
=
require
(
"../../../system"
);
const
settings
=
require
(
"../../../../config/settings"
);
const
appconfig
=
system
.
getSysConfig
();
module
.
exports
=
(
db
,
DataTypes
)
=>
{
//定价类型
return
db
.
define
(
"xproduct"
,
{
path_code
:{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
},
path_name
:{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
},
region_id
:{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
},
region_name
:
{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
},
//和user的from相同,在注册user时,去创建
servicer_name
:{
type
:
DataTypes
.
STRING
,
allowNull
:
false
,
}
},
{
paranoid
:
true
,
//假的删除
underscored
:
true
,
version
:
true
,
freezeTableName
:
true
,
//freezeTableName: true,
// define the table's name
tableName
:
'x_product'
,
getterMethods
:
{
spName
()
{
return
servicer_name
}
},
validate
:
{
},
indexes
:
[
// Create a unique index on email
// {
// unique: true,
// fields: ['email']
// },
//
// // Creates a gin index on data with the jsonb_path_ops operator
// {
// fields: ['data'],
// using: 'gin',
// operator: 'jsonb_path_ops'
// },
//
// // By default index name will be [table]_[fields]
// // Creates a multi column partial index
// {
// name: 'public_by_author',
// fields: ['author', 'status'],
// where: {
// status: 'public'
// }
// },
//
// // A BTREE index with a ordered field
// {
// name: 'title_index',
// method: 'BTREE',
// fields: ['author', {attribute: 'title', collate: 'en_US', order: 'DESC', length: 5}]
// }
]
});
}
center-manage/app/base/service/impl/auth/userSve.js
View file @
86694369
...
...
@@ -369,8 +369,9 @@ class UserService extends ServiceBase {
* @param {*} clientMobile 客户电话
* @param {*} spName 服务商名称
* @param {*} productCatName 产品类型名称
* @param {*} regionName 区域
*/
async
getBizUserForBizChance
(
clientMobile
,
spName
,
productCatName
)
{
async
getBizUserForBizChance
(
clientMobile
,
spName
,
productCatName
,
regionName
)
{
var
self
=
this
//按照服务商名字查询到公司,按照公司查询出users,条件是可以接受派单任务,并且技能标签含有,产品类别名称
return
this
.
db
.
transaction
(
async
function
(
t
)
{
...
...
@@ -398,11 +399,20 @@ class UserService extends ServiceBase {
console
.
log
(
companyFind
)
let
users
=
companyFind
.
us
let
cansels
=
users
.
filter
(
u
=>
{
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
)
{
return
true
}
else
{
return
false
if
(
regionName
&&
regionName
!=
""
){
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
&&
u
.
regiontags
.
indexOf
(
regionName
)
>=
0
)
{
return
true
}
else
{
return
false
}
}
else
{
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
)
{
return
true
}
else
{
return
false
}
}
})
let
lngth
=
cansels
.
length
if
(
lngth
>
0
)
{
...
...
@@ -437,8 +447,9 @@ class UserService extends ServiceBase {
* @param {*} spName 服务商名称
* @param {*} productCatName 产品类型名称
* @param {*} skucode 最小销售货品编码,来自渠道上架的码
* @param {*} regionName 区域
*/
async
getBizUserForDelivery
(
xclientMobile
,
spName
,
productCatName
,
skucode
)
{
async
getBizUserForDelivery
(
xclientMobile
,
spName
,
productCatName
,
skucode
,
regionName
)
{
let
clientMobile
=
'fordeliver'
+
xclientMobile
var
self
=
this
//按照服务商名字查询到公司,按照公司查询出users,条件是可以接受派单任务,并且技能标签含有,产品类别名称
...
...
@@ -486,10 +497,18 @@ class UserService extends ServiceBase {
});
let
users
=
companyFind
.
us
let
cansels
=
users
.
filter
(
u
=>
{
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
)
{
return
true
}
else
{
return
false
if
(
regionName
&&
regionName
!=
""
){
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
&&
u
.
regiontags
.
indexOf
(
regionName
)
>=
0
)
{
return
true
}
else
{
return
false
}
}
else
{
if
(
u
.
isAllocated
&&
u
.
skilltags
.
indexOf
(
productCatName
)
>=
0
)
{
return
true
}
else
{
return
false
}
}
})
let
lngth
=
cansels
.
length
...
...
center-manage/app/base/service/impl/product/productSve.js
View file @
86694369
...
...
@@ -16,7 +16,7 @@ class ProductService extends ServiceBase {
}
async
create
(
p
)
{
if
(
!
p
.
name
||
p
.
name
==
""
)
{
p
.
name
=
p
.
regionpath
+
"~"
+
p
.
productcat
path
p
.
name
=
p
.
productcatpath
+
"~"
+
p
.
region
path
}
//策略ids
let
stragetyids
=
p
.
sts
...
...
center-manage/app/base/service/impl/product/xproductSve.js
0 → 100644
View file @
86694369
const
system
=
require
(
"../../../system"
);
const
ServiceBase
=
require
(
"../../sve.base"
);
class
XProductService
extends
ServiceBase
{
constructor
()
{
super
(
"xproduct"
,
ServiceBase
.
getDaoName
(
XProductService
));
}
async
buildProductCat
()
{
let
ps
=
await
this
.
dao
.
model
.
findAll
({
raw
:
true
})
return
ps
}
}
module
.
exports
=
XProductService
;
function
findTitlePath
(
items
,
findstr
,
results
){
items
.
forEach
(
item
=>
{
if
(
item
.
title
.
indexOf
(
findstr
)
<
0
){
if
(
item
.
children
&&
item
.
children
.
length
>
0
){
return
findTitlePath
(
item
.
children
,
findstr
,
results
)
}
}
else
{
results
.
push
(
item
.
titlepath
)
return
}
})
}
let
ps
=
new
XProductService
()
let
ts
=
system
.
getObject
(
"service.common.treearchSve"
)
let
products
=
[]
ps
.
buildProductCat
().
then
(
res
=>
{
// console.log(JSON.stringify(res))
ts
.
getRegions
().
then
(
rs
=>
{
res
.
forEach
(
xp
=>
{
let
product
=
{}
product
.
code
=
xp
.
path_code
+
xp
.
id
results
=
[]
findTitlePath
(
rs
,
xp
.
region_name
,
results
)
product
.
regionpath
=
results
[
0
]
product
.
productcatpath
=
"产品分类"
+
xp
.
path_name
product
.
name
=
product
.
productcatpath
+
"~"
+
product
.
regionpath
product
.
sptags
=
xp
.
servicer_name
products
.
push
(
product
)
})
console
.
log
(
JSON
.
stringify
(
products
))
})
// { id: 128,
// path_code: '/ic/gsreg/'+id,----->code
// path_name: '/工商服务/公司注册/',+产品分类---->productcatpath
// region_id: '320400',
// region_name: '常州'}--->regionpath
//通过region_name--解析出regionpath
//path_name--添加“产品分类”
//code,regionpath,productcatpath,name
// let treedata={}
// res.forEach(item=>{
// let pathcodes=item.path_code.split("/")
// let pathnames=item.path_name.split("/")
// let pathcoderesults=pathcodes.slice(1,3)
// let pathnameresults=pathnames.slice(1,3)
// let codekey=pathcoderesults[0]
// if(!treedata[codekey]){
// let tmp={}
// tmp["code"]=pathcoderesults[0]
// tmp["title"]=pathnameresults[0]
// tmp["orgpath"]="/"+pathcoderesults[0]
// tmp["titlepath"]="/"+pathnameresults[0]
// tmp.children=[
// {
// code:pathcoderesults[1],
// title:pathnameresults[1],
// orgpath:item.path_code,
// titlepath:item.path_name
// }
// ]
// treedata[codekey]= tmp
// }else{
// let f=treedata[codekey].children.filter(it=>{
// if(it.code==pathcoderesults[1]){
// return true
// }else{
// return false
// }
// })
// if(f.length==0){
// let n={
// code:pathcoderesults[1],
// title:pathnameresults[1],
// orgpath:item.path_code,
// titlepath:item.path_name
// }
// treedata[codekey].children.push(n)
// }
// }
// })
// let root = {
// title: "产品分类",
// code: "root",
// orgpath: "root",
// children: [
// ]
// }
// Object.keys(treedata).forEach(k=>{
// root.children.push(treedata[k])
// })
// console.log(JSON.stringify(root))
})
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment