Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
J
jinfa-platform
Project
Project
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
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
shenshaokai
jinfa-platform
Commits
252817f1
Commit
252817f1
authored
Aug 06, 2021
by
前端-钟卫鹏
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'v2' of
http://10.0.0.22:3000/lingxi/lingxi-business-paltform
into v2
parents
ac146745
e9ffdf8b
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
1041 additions
and
70 deletions
+1041
-70
index.ts
config/routes/index.ts
+1
-0
report.20210804.155111.26372.0.001.json
report.20210804.155111.26372.0.001.json
+0
-0
app.tsx
src/app.tsx
+3
-1
index.less
...nts/AddressSelect/components/AddressRadioGroup/index.less
+56
-0
index.tsx
...ents/AddressSelect/components/AddressRadioGroup/index.tsx
+243
-0
index.less
...Select/components/AddressRadioGroupFormilyItem/index.less
+0
-0
index.tsx
...sSelect/components/AddressRadioGroupFormilyItem/index.tsx
+32
-0
index.less
src/components/AddressSelect/index.less
+28
-0
index.tsx
src/components/AddressSelect/index.tsx
+264
-0
schema.ts
src/components/AddressSelect/schema.ts
+242
-0
CustomAddressSelect.tsx
src/components/NiceForm/components/CustomAddressSelect.tsx
+32
-0
index.tsx
src/components/NiceForm/index.tsx
+2
-0
index.tsx
src/components/NiceForm/public/index.tsx
+8
-2
BasicLayout.tsx
src/layouts/BasicLayout.tsx
+4
-4
MenuSlider.tsx
src/layouts/components/MenuSlider.tsx
+3
-1
RightContent.tsx
src/layouts/components/RightContent.tsx
+48
-29
RightContent.less
src/layouts/styles/RightContent.less
+22
-2
index.ts
...tion/returnPrSubmit/components/ReturnForm/schema/index.ts
+18
-2
index.tsx
src/pages/contract/coordination/details/index.tsx
+18
-17
addList.tsx
src/pages/contract/manage/add/addList.tsx
+3
-2
FormList.tsx
src/pages/contract/manage/add/components/FormList.tsx
+6
-7
index.tsx
src/pages/contract/manage/details/index.tsx
+2
-2
index.tsx
src/pages/home/components/UserCenter/index.tsx
+2
-1
index.tsx
...ifyComingData/components/VerifyComingDataDrawer/index.tsx
+4
-0
No files found.
config/routes/index.ts
View file @
252817f1
...
...
@@ -83,6 +83,7 @@ const memberCenterRoute = {
path
:
'/memberCenter/noAuth'
,
auth
:
false
,
hideInMenu
:
true
,
name
:
'无权限'
,
component
:
'@/pages/403'
,
},
// 能力中心的404页
...
...
report.20210804.155111.26372.0.001.json
deleted
100644 → 0
View file @
ac146745
This diff is collapsed.
Click to expand it.
src/app.tsx
View file @
252817f1
...
...
@@ -120,7 +120,9 @@ export function onRouteChange({ routes, matchedRoutes, location, action }) {
const
breadCrumb
=
matchedRoutes
.
slice
(
2
).
reduce
((
prev
,
current
)
=>
{
return
prev
+=
"."
+
current
.
route
.
name
},
'menu'
)
recent
.
put
(
breadCrumb
,
location
.
pathname
+
location
.
search
);
if
(
breadCrumb
)
{
recent
.
put
(
breadCrumb
,
location
.
pathname
+
location
.
search
);
}
}
// if (isDev) {
...
...
src/components/AddressSelect/components/AddressRadioGroup/index.less
0 → 100644
View file @
252817f1
@import '~antd/es/style/themes/default.less';
@addressList-prefix: addressList;
.@{addressList-prefix} {
display: block;
&-item {
display: flex;
align-items: center;
justify-content: space-between;
padding: @padding-sm - 2 @padding-md;
background-color: @background-color-base;
border-radius: 4px;
cursor: pointer;
box-sizing: border-box;
border: 1px solid transparent;
transition: all .3s;
&:not(:last-child) {
margin-bottom: @margin-md;
}
&:hover {
background-color: @white;
border-color: @primary-color;
.@{addressList-prefix}-item-actions {
visibility: visible;
}
}
&-left {
display: flex;
align-items: center;
}
&-right {
flex-shrink: 0;
}
&-default {
padding: @padding-xss - 2 @padding-xss;
font-size: 12px;
color: #5C626A;
background-color: #EBECF0;
border-radius: 2px;
}
&-actions {
visibility: hidden;
transition: all .3s;
}
}
}
\ No newline at end of file
src/components/AddressSelect/components/AddressRadioGroup/index.tsx
0 → 100644
View file @
252817f1
/*
* @Author: XieZhiXiong
* @Date: 2021-08-05 14:23:40
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-08-05 18:12:24
* @Description: 地址单选框组
*/
import
React
,
{
useState
,
useEffect
,
useMemo
}
from
'react'
;
import
{
Radio
,
Button
,
Modal
,
message
}
from
'antd'
;
import
{
ExclamationCircleOutlined
}
from
'@ant-design/icons'
;
import
{
PublicApi
}
from
'@/services/api'
;
import
{
GetLogisticsShipperAddressGetResponse
,
GetLogisticsReceiverAddressGetResponse
}
from
'@/services/LogisticsApi'
;
import
{
IRequestSuccess
}
from
'@/index'
;
import
styles
from
'./index.less'
;
const
{
confirm
}
=
Modal
;
export
type
AddressItemType
=
{
/**
* 主键id
*/
id
:
number
,
/**
* 发货人名称
*/
shipperName
:
string
,
/**
* 收件人名称
*/
receiverName
:
string
,
/**
* 发货地址
*/
fullAddress
:
string
,
/**
* 手机号码
*/
phone
:
string
,
/**
* 是否默认0-否1-是
*/
isDefault
:
number
,
}
export
type
AddressValueType
=
Omit
<
AddressItemType
,
'shipperName'
|
'receiverName'
>
&
{
/**
* 寄件人 或者 收件人名称
*/
name
:
string
,
}
interface
IProps
{
/**
* 类型:1 收货地址 2 发货地址,默认 2
*/
addressType
:
1
|
2
,
/**
* 值
*/
value
?:
AddressValueType
,
/**
* 选择触发改变
*/
onChange
?:
(
value
:
AddressValueType
)
=>
void
,
/**
* 是否默认选择 默认地址,是的话会触发 onChange value为默认地址,默认为false
*/
isDefaultAddress
?:
boolean
,
}
const
AddressRadioGroup
:
React
.
FC
<
IProps
>
=
(
props
)
=>
{
const
{
addressType
=
2
,
value
,
onChange
,
isDefaultAddress
=
false
,
}
=
props
;
const
[
list
,
setList
]
=
useState
<
AddressValueType
[]
>
([]);
const
[
internalValue
,
setInternalValue
]
=
useState
<
AddressValueType
|
undefined
>
(
undefined
);
const
triggerChange
=
(
value
:
AddressValueType
)
=>
{
if
(
onChange
)
{
onChange
(
value
);
}
};
const
getAddressList
=
()
=>
{
const
fetchAction
=
addressType
===
2
?
PublicApi
.
getLogisticsSelectListShipperAddress
()
:
PublicApi
.
getLogisticsSelectListReceiverAddress
();
fetchAction
.
then
((
res
:
IRequestSuccess
<
AddressItemType
[]
>
)
=>
{
if
(
res
.
code
===
1000
)
{
const
defaultItem
=
res
.
data
?.
find
((
item
)
=>
item
.
isDefault
);
setList
(
res
.
data
?.
map
(({
shipperName
,
receiverName
,
...
rest
})
=>
({
name
:
shipperName
||
receiverName
,
...
rest
,
})));
if
(
isDefaultAddress
&&
defaultItem
)
{
const
{
shipperName
,
receiverName
,
...
rest
}
=
defaultItem
;
triggerChange
({
name
:
shipperName
||
receiverName
,
...
rest
,
});
}
}
}).
catch
((
err
)
=>
{
console
.
warn
(
err
);
});
};
useEffect
(()
=>
{
if
(
'value'
in
props
)
{
setInternalValue
(
value
);
}
},
[
value
]);
useEffect
(()
=>
{
getAddressList
();
},
[]);
const
handleSelectItem
=
(
id
:
number
)
=>
{
const
current
=
list
.
find
((
item
)
=>
item
.
id
===
id
);
if
(
!
(
'value'
in
props
))
{
setInternalValue
(
current
);
}
if
(
current
)
{
triggerChange
(
current
);
}
};
const
handleRadioClick
=
(
e
:
React
.
MouseEvent
<
HTMLElement
,
MouseEvent
>
)
=>
{
e
.
stopPropagation
();
};
const
handleEdit
=
(
e
:
React
.
MouseEvent
<
HTMLElement
,
MouseEvent
>
,
id
:
number
)
=>
{
e
.
stopPropagation
();
};
const
handleDelete
=
(
e
:
React
.
MouseEvent
<
HTMLElement
,
MouseEvent
>
,
id
:
number
)
=>
{
e
.
stopPropagation
();
confirm
({
title
:
'提示'
,
icon
:
<
ExclamationCircleOutlined
/>,
content
:
`是否需要删除该地址信息?`
,
onOk
()
{
return
(
addressType
===
2
?
PublicApi
.
postLogisticsShipperAddressDelete
({
id
})
:
PublicApi
.
postLogisticsReceiverAddressDelete
({
id
})
);
},
});
};
// 设置默认地址,这里直接调用修改地址接口
const
handleSetDefaultItem
=
async
(
e
:
React
.
MouseEvent
<
HTMLElement
,
MouseEvent
>
,
id
:
number
)
=>
{
e
.
stopPropagation
();
const
mesInstance
=
message
.
loading
({
content
:
'正在设置'
,
duration
:
0
,
});
try
{
const
res
=
addressType
===
2
?
await
PublicApi
.
getLogisticsShipperAddressGet
({
id
:
`
${
id
}
`
})
:
await
PublicApi
.
getLogisticsReceiverAddressGet
({
id
:
`
${
id
}
`
});
if
(
res
.
code
===
1000
)
{
addressType
===
2
?
await
PublicApi
.
postLogisticsShipperAddressUpdate
({
...(
res
.
data
as
GetLogisticsShipperAddressGetResponse
),
isDefault
:
1
,
})
:
await
PublicApi
.
postLogisticsReceiverAddressUpdate
({
...(
res
.
data
as
GetLogisticsReceiverAddressGetResponse
),
isDefault
:
1
,
});
}
}
catch
(
error
)
{
console
.
warn
(
error
);
}
mesInstance
();
};
const
options
=
useMemo
(()
=>
{
return
list
.
map
((
item
)
=>
({
value
:
item
.
id
,
label
:
`
${
item
.
name
}
${
item
.
fullAddress
}
${
item
.
phone
}
`
,
isDefault
:
!!
item
.
isDefault
,
}));
},
[
list
]);
return
(
<
div
className=
{
styles
.
addressList
}
>
<
Radio
.
Group
value=
{
internalValue
?.
id
}
style=
{
{
display
:
'block'
}
}
>
{
options
.
map
((
item
)
=>
(
<
div
key=
{
item
.
value
}
className=
{
styles
[
'addressList-item'
]
}
onClick=
{
()
=>
handleSelectItem
(
item
.
value
)
}
>
<
div
className=
{
styles
[
'addressList-item-left'
]
}
>
<
Radio
value=
{
item
.
value
}
onClick=
{
handleRadioClick
}
>
{
item
.
label
}
</
Radio
>
{
item
.
isDefault
?
(
<
span
className=
{
styles
[
'addressList-item-default'
]
}
>
默认地址
</
span
>
)
:
(
<
div
className=
{
styles
[
'addressList-item-actions'
]
}
>
<
Button
type=
"text"
size=
"small"
onClick=
{
(
e
)
=>
handleSetDefaultItem
(
e
,
item
.
value
)
}
>
设为默认地址
</
Button
>
</
div
>
)
}
</
div
>
<
div
className=
{
styles
[
'addressList-item-right'
]
}
>
<
div
className=
{
styles
[
'addressList-item-actions'
]
}
>
<
Button
type=
"text"
size=
"small"
onClick=
{
(
e
)
=>
handleEdit
(
e
,
item
.
value
)
}
>
编辑
</
Button
>
<
Button
type=
"text"
size=
"small"
onClick=
{
(
e
)
=>
handleDelete
(
e
,
item
.
value
)
}
>
删除
</
Button
>
</
div
>
</
div
>
</
div
>
))
}
</
Radio
.
Group
>
</
div
>
);
};
export
default
AddressRadioGroup
;
src/components/AddressSelect/components/AddressRadioGroupFormilyItem/index.less
0 → 100644
View file @
252817f1
src/components/AddressSelect/components/AddressRadioGroupFormilyItem/index.tsx
0 → 100644
View file @
252817f1
/*
* @Author: XieZhiXiong
* @Date: 2021-08-05 14:54:18
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-08-05 14:54:19
* @Description:
*/
import
React
from
'react'
;
import
{
connect
}
from
'@formily/antd'
;
import
AddressRadioGroup
from
'../AddressRadioGroup'
;
const
AddressRadioGroupFormilyItem
=
connect
()((
props
)
=>
{
const
{
dataSource
,
value
,
onChange
,
addressType
,
...
rest
}
=
props
;
return
(
<
div
style=
{
{
flex
:
1
}
}
>
<
AddressRadioGroup
addressType=
{
addressType
}
value=
{
value
}
onChange=
{
onChange
}
{
...
rest
}
/>
</
div
>
);
});
export
default
AddressRadioGroupFormilyItem
;
src/components/AddressSelect/index.less
0 → 100644
View file @
252817f1
@import '~antd/es/style/themes/default.less';
.address-select {
display: flex;
align-items: center;
&-input {
flex: 1;
}
&-action {
margin-left: @margin-md;
}
}
.label-required {
font-size: 12px;
color: #909399;
&::after {
margin-left: 8px;
font-size: 12px;
font-family: SimSun, sans-serif;
color: #ff4d4f;
content: '*';
}
}
\ No newline at end of file
src/components/AddressSelect/index.tsx
0 → 100644
View file @
252817f1
/*
* @Author: XieZhiXiong
* @Date: 2021-08-05 10:28:06
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-08-05 18:37:33
* @Description: 地址选择 FormItem
*/
import
React
,
{
useState
,
useEffect
,
useMemo
}
from
'react'
;
import
{
Select
,
Button
,
Drawer
,
Divider
}
from
'antd'
;
import
{
PublicApi
}
from
'@/services/api'
;
import
{
createAsyncFormActions
,
FormEffectHooks
,
}
from
'@formily/antd'
;
import
{
DatePicker
}
from
'@formily/antd-components'
;
import
{
IRequestSuccess
}
from
'@/index'
;
import
{
useLinkEnumEffect
}
from
'@/components/NiceForm/linkages/linkEnum'
;
import
{
useAsyncSelect
}
from
'@/formSchema/effects/useAsyncSelect'
;
import
NiceForm
from
'@/components/NiceForm'
;
import
{
schema
}
from
'./schema'
;
import
{
AddressItemType
,
AddressValueType
}
from
'./components/AddressRadioGroup'
;
import
AddressRadioGroup
from
'./components/AddressRadioGroupFormilyItem'
;
import
styles
from
'./index.less'
;
const
formActions
=
createAsyncFormActions
();
const
{
onFormMount$
,
onFieldValueChange$
,
}
=
FormEffectHooks
;
interface
IProps
{
/**
* 类型:1 收货地址 2 发货地址,默认 2
*/
addressType
?:
1
|
2
,
/**
* 值
*/
value
?:
AddressValueType
,
/**
* 选择触发改变
*/
onChange
?:
(
value
:
AddressValueType
)
=>
void
,
/**
* 是否默认选择 默认地址,是的话会触发 onChange value为默认地址,默认为false
*/
isDefaultAddress
?:
boolean
,
}
export
type
SubmitValuesType
=
{
/**
* 地址单选选中的值
*/
address
?:
AddressValueType
,
/**
* 收件人名称 或 发货人名称
*/
name
:
string
,
/**
* 省级id
*/
provinceId
:
number
,
/**
* 市级id
*/
cityId
:
number
,
/**
* 区级id
*/
areaId
:
number
,
/**
* 详细地址
*/
detailed
:
string
,
/**
* 邮编
*/
postalCode
:
string
,
/**
* 区号
*/
telCode
:
string
,
/**
* 手机号码
*/
phone
:
string
,
/**
* 电话号码
*/
tel
:
string
,
/**
* 是否是默认
*/
isDefault
:
boolean
,
}
const
AddressSelect
:
React
.
FC
<
IProps
>
=
(
props
)
=>
{
const
{
addressType
=
2
,
value
,
onChange
,
isDefaultAddress
=
false
,
}
=
props
;
const
[
options
,
setOptions
]
=
useState
<
{
label
,
value
}[]
>
([]);
const
[
internalValue
,
setInternalValue
]
=
useState
<
AddressValueType
>
();
const
[
visibleDrawer
,
setVisibleDrawer
]
=
useState
(
false
);
const
[
submitLoading
,
setSubmitLoading
]
=
useState
(
false
);
const
triggerChange
=
(
value
:
AddressValueType
)
=>
{
if
(
onChange
)
{
onChange
(
value
);
}
};
const
getAddressList
=
()
=>
{
const
fetchAction
=
addressType
===
2
?
PublicApi
.
getLogisticsSelectListShipperAddress
()
:
PublicApi
.
getLogisticsSelectListReceiverAddress
();
fetchAction
.
then
((
res
:
IRequestSuccess
<
AddressItemType
[]
>
)
=>
{
if
(
res
.
code
===
1000
)
{
const
defaultItem
=
res
.
data
?.
find
((
item
)
=>
item
.
isDefault
);
setOptions
(
res
.
data
?.
map
((
item
)
=>
({
value
:
item
.
id
,
label
:
`
${
item
.
shipperName
||
item
.
receiverName
}
${
item
.
fullAddress
}
${
item
.
phone
}
`
})));
if
(
isDefaultAddress
&&
defaultItem
)
{
const
{
shipperName
,
receiverName
,
...
rest
}
=
defaultItem
;
triggerChange
({
name
:
shipperName
||
receiverName
,
...
rest
,
});
}
}
}).
catch
((
err
)
=>
{
console
.
warn
(
err
);
});
};
// 获取手机code
const
fetchTelCode
=
async
()
=>
{
const
{
data
,
code
}
=
await
PublicApi
.
getManageCountryAreaGetTelCode
();
if
(
code
===
1000
)
{
return
data
;
}
return
[];
};
useEffect
(()
=>
{
getAddressList
();
},
[]);
const
handleVisibleDrawer
=
(
flag
?:
boolean
)
=>
{
setVisibleDrawer
(
!!
flag
);
};
const
handleSubmit
=
(
values
:
SubmitValuesType
)
=>
{
console
.
log
(
'values'
,
values
)
};
const
useFields
=
():
any
=>
(
useMemo
(()
=>
({
AddressRadioGroup
,
}),
[])
);
const
AddressLabel
=
(
<
div
className=
{
styles
[
'label-required'
]
}
>
收件地区
</
div
>
);
const
handleAddAddress
=
()
=>
{
formActions
.
setFieldState
(
'ADDRESS_NEW'
,
state
=>
{
state
.
visible
=
!
state
.
visible
;
});
};
const
AddButton
=
useMemo
(()
=>
{
return
()
=>
(
<
div
>
<
Button
onClick=
{
handleAddAddress
}
>
新增收货地址
</
Button
>
<
Divider
style=
{
{
marginBottom
:
4
}
}
/>
</
div
>
);
},
[]);
return
(
<>
<
div
className=
{
styles
[
'address-select'
]
}
>
<
Select
options=
{
options
}
value=
{
value
?.
id
}
/>
<
Button
onClick=
{
()
=>
handleVisibleDrawer
(
true
)
}
className=
{
styles
[
'address-select-action'
]
}
>
管理
</
Button
>
</
div
>
<
Drawer
title=
"更改收货地址信息"
width=
{
800
}
onClose=
{
()
=>
handleVisibleDrawer
(
false
)
}
visible=
{
visibleDrawer
}
footer=
{
<
div
style=
{
{
textAlign
:
'right'
,
}
}
>
<
Button
onClick=
{
()
=>
handleVisibleDrawer
(
false
)
}
style=
{
{
marginRight
:
16
}
}
>
取 消
</
Button
>
<
Button
onClick=
{
()
=>
formActions
.
submit
()
}
type=
"primary"
loading=
{
submitLoading
}
>
确 定
</
Button
>
</
div
>
}
destroyOnClose
>
<
NiceForm
previewPlaceholder=
"' '"
components=
{
{
AddButton
,
}
}
expressionScope=
{
{
AddressLabel
,
}
}
fields=
{
useFields
()
}
effects=
{
(
$
,
{
setFieldState
})
=>
{
onFormMount$
().
subscribe
(
async
()
=>
{
const
areaRes
=
await
PublicApi
.
getManageAreaAll
();
if
(
areaRes
.
code
===
1000
)
{
const
{
data
}
=
areaRes
;
formActions
.
setFieldState
(
'provinceId'
,
targetState
=>
{
targetState
.
originData
=
data
;
targetState
.
props
.
enum
=
data
.
map
(
v
=>
({
label
:
v
.
name
,
value
:
v
.
id
,
}));
});
}
});
useLinkEnumEffect
(
'areaResponses'
,
result
=>
result
.
map
(
v
=>
({
label
:
v
.
name
,
value
:
v
.
id
,
})));
useAsyncSelect
(
'telCode'
,
fetchTelCode
);
}
}
actions=
{
formActions
}
schema=
{
schema
}
onSubmit=
{
values
=>
handleSubmit
(
values
)
}
/>
</
Drawer
>
</>
);
};
export
default
AddressSelect
;
src/components/AddressSelect/schema.ts
0 → 100644
View file @
252817f1
/*
* @Author: XieZhiXiong
* @Date: 2021-08-05 14:02:46
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-08-05 18:34:01
* @Description:
*/
import
{
ISchema
}
from
'@formily/antd'
;
import
{
PATTERN_MAPS
}
from
'@/constants/regExp'
;
export
const
schema
:
ISchema
=
{
type
:
'object'
,
properties
:
{
ADDRESS_LIST
:
{
type
:
'object'
,
'x-component'
:
'FlagBox'
,
'x-component-props'
:
{
title
:
'选择收货地址'
,
border
:
false
,
},
properties
:
{
MEGA_LAYOUT_1
:
{
type
:
'object'
,
'x-component'
:
'Mega-Layout'
,
'x-component-props'
:
{
wrapperCol
:
24
,
},
properties
:
{
address
:
{
type
:
'string'
,
'x-component'
:
'AddressRadioGroup'
,
'x-component-props'
:
{},
'x-rules'
:
[
{
required
:
true
,
message
:
'请选择地址'
,
},
],
},
},
},
},
},
ADD_ACTION
:
{
type
:
'object'
,
'x-component'
:
'AddButton'
,
},
ADDRESS_NEW
:
{
type
:
'object'
,
'x-component'
:
'FlagBox'
,
'x-component-props'
:
{
title
:
'填写收货信息'
,
border
:
false
,
},
visible
:
false
,
properties
:
{
MEGA_LAYOUT_2
:
{
type
:
'object'
,
'x-component'
:
'mega-layout'
,
'x-component-props'
:
{
labelCol
:
4
,
wrapperCol
:
20
,
labelAlign
:
'left'
,
},
properties
:
{
name
:
{
type
:
'string'
,
title
:
'收件人'
,
'x-component-props'
:
{
placeholder
:
'请输入'
,
},
'x-rules'
:
[
{
required
:
true
,
message
:
'请输入收件人'
,
},
{
limitByte
:
true
,
// 自定义校验规则
maxByte
:
10
,
}
],
required
:
true
,
},
MEGA_LAYOUT_2_1
:
{
type
:
'object'
,
'x-component'
:
'mega-layout'
,
'x-component-props'
:
{
label
:
'{{AddressLabel}}'
,
wrapperCol
:
24
,
},
required
:
true
,
properties
:
{
MEGA_LAYOUT_2_1_1
:
{
type
:
'object'
,
'x-component'
:
'mega-layout'
,
'x-component-props'
:
{
grid
:
true
,
full
:
true
,
autoRow
:
true
,
columns
:
3
,
},
properties
:
{
provinceId
:
{
type
:
'string'
,
enum
:
[],
'x-component-props'
:
{
placeholder
:
'- 省 -'
,
},
'x-linkages'
:
[
{
type
:
'value:linkage'
,
condition
:
'{{ !!$self.value }}'
,
// $value,不触发不知道咋回事
origin
:
'provinceId'
,
target
:
'cityId'
,
},
],
required
:
true
,
},
cityId
:
{
type
:
'string'
,
enum
:
[],
'x-component-props'
:
{
placeholder
:
'- 市 -'
,
},
'x-linkages'
:
[
{
type
:
'value:linkage'
,
condition
:
'{{ !!$self.value }}'
,
// $value,不触发不知道咋回事
origin
:
'cityId'
,
target
:
'areaId'
,
},
],
required
:
true
,
},
areaId
:
{
type
:
'string'
,
enum
:
[],
'x-component-props'
:
{
placeholder
:
'- 县 / 区 -'
,
},
required
:
true
,
},
},
},
},
},
detailed
:
{
type
:
'string'
,
title
:
'详细地址'
,
'x-component-props'
:
{
placeholder
:
'请输入详细地址(最长50个字符,25个汉字)'
,
},
'x-rules'
:
[
{
required
:
true
,
message
:
'请输入详细地址'
,
},
{
limitByte
:
true
,
// 自定义校验规则
maxByte
:
50
,
}
],
},
postalCode
:
{
type
:
'string'
,
title
:
'邮编'
,
'x-component-props'
:
{},
'x-rules'
:
[
{
limitByte
:
true
,
// 自定义校验规则
maxByte
:
16
,
}
],
},
MEGA_LAYOUT_2_2
:
{
type
:
'object'
,
'x-component'
:
'mega-layout'
,
'x-component-props'
:
{
label
:
'手机号码'
,
wrapperCol
:
24
,
},
properties
:
{
MEGA_LAYOUT2_1
:
{
type
:
'object'
,
'x-component'
:
'mega-layout'
,
'x-component-props'
:
{
grid
:
true
,
full
:
true
,
},
properties
:
{
telCode
:
{
type
:
'string'
,
enum
:
[],
'x-component-props'
:
{
placeholder
:
'请选择'
,
},
required
:
true
,
},
phone
:
{
type
:
'string'
,
required
:
true
,
'x-mega-props'
:
{
span
:
3
,
},
'x-component-props'
:
{
placeholder
:
'请输入你的手机号码'
,
maxLength
:
11
,
},
'x-rules'
:
[
{
pattern
:
PATTERN_MAPS
.
phone
,
message
:
'请输入正确格式的手机号'
,
},
],
},
},
},
},
},
tel
:
{
type
:
'string'
,
title
:
'电话号码'
,
'x-component-props'
:
{},
'x-rules'
:
[
{
limitByte
:
true
,
// 自定义校验规则
maxByte
:
16
,
}
],
},
isDefault
:
{
type
:
'boolean'
,
title
:
'是否默认'
,
'x-component'
:
'Switch'
,
},
},
},
},
},
},
};
\ No newline at end of file
src/components/NiceForm/components/CustomAddressSelect.tsx
0 → 100644
View file @
252817f1
/*
* @Author: XieZhiXiong
* @Date: 2021-08-05 11:26:43
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-08-05 11:30:21
* @Description:
*/
import
React
from
'react'
;
import
{
connect
}
from
'@formily/antd'
;
import
AddressSelect
from
'@/components/AddressSelect'
;
const
CustomAddressSelect
=
connect
()((
props
)
=>
{
const
{
dataSource
,
value
,
onChange
,
addressType
,
...
rest
}
=
props
;
return
(
<
div
style=
{
{
flex
:
1
}
}
>
<
AddressSelect
addressType=
{
addressType
}
value=
{
value
}
onChange=
{
onChange
}
{
...
rest
}
/>
</
div
>
);
});
export
default
CustomAddressSelect
;
src/components/NiceForm/index.tsx
View file @
252817f1
...
...
@@ -36,6 +36,7 @@ import AreaSelect from './components/AreaSelect';
import
CustomSelect
from
'./components/CustomSelect'
;
import
CheckboxGroup
from
'./components/CheckboxGroup'
;
import
CustomRadioGroup
from
'./components/CustomRadioGroup'
;
import
CustomAddressSelect
from
'./components/CustomAddressSelect'
;
import
{
useLinkComponentProps
}
from
'./linkages/linkComponentProps'
;
import
Loading
from
'../Loading'
;
import
MultAddress
from
'./components/MultAddress'
;
...
...
@@ -129,6 +130,7 @@ export const componentExport = {
CustomSelect
,
CheckboxGroup
,
CustomRadioGroup
,
CustomAddressSelect
,
Switch
,
}
const
NiceForm
:
React
.
FC
<
NiceFormProps
>
=
props
=>
{
...
...
src/components/NiceForm/public/index.tsx
View file @
252817f1
...
...
@@ -18,11 +18,13 @@ const RowLayout = styled(props => <Row justify='end' {...props}/>)`
const
FlagBox
=
styled
(
props
=>
<
div
{
...
props
}
/>)
`
.flag-box-title {
padding-left:
${
themeConfig
[
'@padding-xs'
]}
;
margin-bottom:
${
themeConfig
[
'@margin-lg'
]}
;
line-height:
${
themeConfig
[
'@font-size-lg'
]}
;
font-size:
${
themeConfig
[
'@font-size-lg'
]}
;
font-weight: 500;
}
.flag-box-title.border {
padding-left:
${
themeConfig
[
'@padding-xs'
]}
;
border-left: 2px solid
${
themeConfig
[
'@primary-color'
]}
;
}
`
...
...
@@ -111,12 +113,16 @@ registerVirtualBox('LeftRightLayout', (_props) => {
registerVirtualBox
(
'FlagBox'
,
(
_props
)
=>
{
const
{
children
,
props
}
=
_props
;
const
title
=
props
[
'x-component-props'
]
?
props
[
'x-component-props'
].
title
:
''
;
const
border
=
props
[
'x-component-props'
]
?
props
[
'x-component-props'
].
border
||
true
:
true
;
const
wrapProps
=
props
[
'x-component-props'
]
?
props
[
'x-component-props'
].
wrapProps
:
{};
const
titleCls
=
cx
(
'flag-box-title'
,
{
'border'
:
border
});
return
(
<
FlagBox
{
...
wrapProps
}
>
<
div
className=
"flag-box-title"
>
<
div
className=
{
titleCls
}
>
{
title
}
</
div
>
<
div
>
...
...
src/layouts/BasicLayout.tsx
View file @
252817f1
...
...
@@ -6,7 +6,7 @@ import ProLayout, {
getMenuData
,
getPageTitle
}
from
'@ant-design/pro-layout'
;
import
React
,
{
useState
,
useEffect
,
useLayoutEffect
}
from
'react'
;
import
React
,
{
useState
,
useEffect
,
useLayoutEffect
,
useMemo
}
from
'react'
;
import
{
Link
,
useIntl
,
Helmet
}
from
'umi'
;
import
RightContent
from
'./components/RightContent'
;
import
{
GlobalConfig
}
from
'@/global/config'
;
...
...
@@ -149,7 +149,7 @@ const BasicLayout: React.FC<BasicLayoutProps> = (props) => {
const
prolayoutStyle
=
isHome
?
{
minHeight
:
'100vh'
,
minWidth
:
'1280px'
minWidth
:
'1280px'
,
}
:
{}
...
...
@@ -162,7 +162,7 @@ const BasicLayout: React.FC<BasicLayoutProps> = (props) => {
// formatMessage={formatMessage}
menuHeaderRender=
{
(
logoDom
,
titleDom
)
=>
(
<
Link
to=
"/"
>
{
logoDom
}
{
/* {logoDom} */
}
{
titleDom
}
</
Link
>
)
}
...
...
@@ -182,7 +182,7 @@ const BasicLayout: React.FC<BasicLayoutProps> = (props) => {
changeOpenKeys=
{
(
keys
:
string
[])
=>
setOpenKeys
(
keys
)
}
/>
}
footerRender=
{
()
=>
defaultFooterDom
}
rightContentRender=
{
()
=>
<
RightContent
/>
}
rightContentRender=
{
()
=>
<
RightContent
isHome=
{
isHome
}
/>
}
{
...
props
}
{
...
settings
}
>
...
...
src/layouts/components/MenuSlider.tsx
View file @
252817f1
...
...
@@ -91,7 +91,9 @@ const MenuSlider: React.FC<MenuSliderProps> = (props) => {
return
<>
<
OuterSider
{
...
props
}
/>
<
Sider
theme=
"light"
className=
"menu_sider"
collapsed=
{
props
.
collapseState
}
>
<
div
className=
{
styles
.
logo
}
><
img
src=
{
GlobalConfig
.
global
.
siteInfo
.
logo
}
/></
div
>
<
Link
to=
{
`/`
}
className=
{
styles
.
logo
}
>
<
img
src=
{
GlobalConfig
.
global
.
siteInfo
.
logo
}
/>
</
Link
>
<
div
className=
{
styles
.
menuTitle
}
>
{
menuRouter
?.
name
}
</
div
>
...
...
src/layouts/components/RightContent.tsx
View file @
252817f1
import
{
Tooltip
,
Badge
}
from
'antd'
;
import
{
BellOutlined
,
CustomerServiceOutlined
}
from
'@ant-design/icons'
;
import
React
,
{
useCallback
,
useRef
,
useLayoutEffect
,
useState
,
useEffect
}
from
'react'
;
import
React
,
{
useCallback
,
useRef
,
useLayoutEffect
,
useState
,
useEffect
,
useMemo
}
from
'react'
;
import
Avatar
from
'./AvatarDropdown'
;
import
SelectLang
from
'./SelectLang'
;
import
Location
from
'./Location'
;
...
...
@@ -12,6 +12,7 @@ import { getAuth } from '@/utils/auth';
import
{
getCookie
}
from
'@/utils/cookie'
import
{
notificationChatRoom
}
from
'@/utils/im'
import
{
SOCKET_URL
,
PLATFORM_DOMAIN
}
from
'@/constants'
;
import
{
GlobalConfig
}
from
'@/global/config'
;
import
{
usePurchaseBidStore
}
from
'@/store/purchaseBid'
;
...
...
@@ -38,8 +39,8 @@ type WsMessage = {
timestamp
:
number
}
const
GlobalHeaderRight
:
React
.
FC
<
{
SiteStore
?:
any
}
>
=
(
props
)
=>
{
const
{
SiteStore
:
{
currentLayoutInfo
}
}
=
props
;
const
GlobalHeaderRight
:
React
.
FC
<
{
SiteStore
?:
any
,
isHome
:
boolean
}
>
=
(
props
)
=>
{
const
{
SiteStore
:
{
currentLayoutInfo
}
,
isHome
}
=
props
;
const
[
message
,
setMessage
]
=
useState
<
number
>
(
0
);
const
className
=
styles
.
right
;
...
...
@@ -73,7 +74,7 @@ const GlobalHeaderRight: React.FC<{ SiteStore?: any }> = (props) => {
if
(
data
.
action
===
'msg_no_read_message'
)
{
setMessage
(
+
data
.
data
);
}
};
ws
.
current
.
onclose
=
(
e
)
=>
{
console
.
log
(
"关闭连接"
)
...
...
@@ -82,7 +83,7 @@ const GlobalHeaderRight: React.FC<{ SiteStore?: any }> = (props) => {
console
.
log
(
"socket 出错"
)
}
}
},
[
ws
]);
},
[
ws
,
userInfo
]);
useEffect
(()
=>
{
webSocketInit
();
...
...
@@ -99,34 +100,52 @@ const GlobalHeaderRight: React.FC<{ SiteStore?: any }> = (props) => {
window
.
location
.
href
=
PLATFORM_DOMAIN
}
}
const
cacheStyle
=
useMemo
(()
=>
{
return
{
isHome
:
{
marginLeft
:
'-40px'
},
iamge
:
{
height
:
"30px"
,
marginRight
:
'12px'
}
}
},
[])
return
(
<
div
className=
{
className
}
>
<
span
style=
{
{
color
:
'rgba(0, 0, 0, 0.85)'
,
cursor
:
"pointer"
}
}
onClick=
{
handleBackMall
}
>
返回商城
</
span
>
<
Roles
/>
{
/* <Location /> */
}
<
SelectLang
/>
<
Tooltip
title=
"消息"
>
<
Link
to=
"/memberCenter/systemSetting/message"
className=
{
styles
.
action
}
>
<
Badge
count=
{
message
}
size=
{
"small"
}
>
<
BellOutlined
/>
</
Badge
>
<
div
>
<
Link
to=
{
"/memberCenter/home"
}
className=
{
styles
.
container
}
style=
{
isHome
?
cacheStyle
.
isHome
:
{}
}
>
{
isHome
&&
(
<
img
src=
{
GlobalConfig
.
global
.
siteInfo
.
logo
}
style=
{
cacheStyle
.
iamge
}
/>
)
}
<
span
>
{
GlobalConfig
.
global
.
siteInfo
.
name
}
</
span
>
</
Link
>
</
Tooltip
>
{
/* <Tooltip title="服务">
<a
target="_blank"
href=""
rel="noopener noreferrer"
className={styles.action}
>
<CustomerServiceOutlined />
</a>
</Tooltip> */
}
<
Avatar
/>
</
div
>
<
div
className=
{
styles
.
rightContent
}
>
<
span
style=
{
{
color
:
'rgba(0, 0, 0, 0.85)'
,
cursor
:
"pointer"
}
}
onClick=
{
handleBackMall
}
>
返回商城
</
span
>
<
Roles
/>
{
/* <Location /> */
}
<
SelectLang
/>
<
Tooltip
title=
"消息"
>
<
Link
to=
"/memberCenter/systemSetting/message"
className=
{
styles
.
action
}
>
<
Badge
count=
{
message
}
size=
{
"small"
}
>
<
BellOutlined
/>
</
Badge
>
</
Link
>
</
Tooltip
>
{
/* <Tooltip title="服务">
<a
target="_blank"
href=""
rel="noopener noreferrer"
className={styles.action}
>
<CustomerServiceOutlined />
</a>
</Tooltip> */
}
<
Avatar
/>
</
div
>
</
div
>
);
};
...
...
src/layouts/styles/RightContent.less
View file @
252817f1
...
...
@@ -14,12 +14,32 @@
.right {
display: flex;
float: right;
flex-direction: row;
align-items: center;
width: 100%;
// float: right;
height: @layout-header-height;
margin-left: auto;
overflow: hidden;
//
overflow: hidden;
font-size: 12px;
padding: 0 16px;
position: relative;
justify-content: space-between;
.container {
font-size: 16px;
display: flex;
flex-direction: row;
align-items: center;
color: #000;
}
.rightContent {
display: flex;
flex-direction: row;
align-items: center;
}
.action {
display: flex;
...
...
src/pages/afterService/returnApplication/returnPrSubmit/components/ReturnForm/schema/index.ts
View file @
252817f1
...
...
@@ -463,14 +463,30 @@ export const addSchema = (orderType: number): ISchema => {
},
],
},
// // 退货发货地址
// shippingAddress: {
// title: '退货发货地址',
// type: 'string',
// visible: false,
// 'x-component': 'AddressFormItem',
// 'x-component-props': {
// dataSource: [],
// },
// 'x-rules': [
// {
// required: true,
// message: '请选择退货发货地址',
// },
// ],
// },
// 退货发货地址
shippingAddress
:
{
title
:
'退货发货地址'
,
type
:
'string'
,
visible
:
false
,
'x-component'
:
'
AddressFormItem
'
,
'x-component'
:
'
CustomAddressSelect
'
,
'x-component-props'
:
{
dataSource
:
[]
,
isDefaultAddress
:
true
,
},
'x-rules'
:
[
{
...
...
src/pages/contract/coordination/details/index.tsx
View file @
252817f1
...
...
@@ -198,26 +198,27 @@ const Details = (props: any) => {
}
/* 提交表单 */
const
submitExamine
=
async
()
=>
{
let
flag
=
false
;
ListData
.
every
((
item
=>
{
if
(
item
.
associatedDataId
&&
item
.
associatedMaterielNo
)
{
flag
=
true
;
if
(
type
===
'Sign'
&&
contractText
.
isUseElectronicContract
==
1
)
{
console
.
log
(
signatureLogId
)
let
res
=
await
PublicApi
.
getContractSignatureGetHandSignatureUrl
({
signatureLogId
,
});
if
(
res
.
code
==
1000
)
{
console
.
log
(
res
);
window
.
open
(
res
.
data
.
url
)
}
}))
if
(
!
flag
)
{
message
.
info
(
'请先关联报价商品'
);
}
else
{
if
(
type
===
'Sign'
&&
contractText
.
isUseElectronicContract
==
1
)
{
console
.
log
(
signatureLogId
)
let
res
=
await
PublicApi
.
getContractSignatureGetHandSignatureUrl
({
signatureLogId
:
98
});
if
(
res
.
code
==
1000
)
{
console
.
log
(
res
);
window
.
open
(
res
.
data
.
url
)
}
}
else
{
setIsModalVisible
(
!
Visible
)
}
setIsModalVisible
(
!
Visible
)
}
// let flag = false;
// ListData.every((item => {
// if (item.associatedDataId && item.associatedMaterielNo) {
// flag = true;
// }
// }))
// if (!flag) {
// message.info('请先关联报价商品');
// } else {
// }
}
const
handleIsAllMemberChange
=
(
v
:
any
)
=>
{
...
...
src/pages/contract/manage/add/addList.tsx
View file @
252817f1
...
...
@@ -128,6 +128,7 @@ const addList = () => {
// 甲方不同意签订合同都可以修改
return
(
<
div
>
<
span
style=
{
{
color
:
'#00B37A'
,
cursor
:
'pointer'
,
marginRight
:
10
}
}
onClick=
{
()
=>
submit
(
record
.
id
)
}
>
提交
</
span
>
{
record
.
innerStatus
==
'1'
||
record
.
outerStatus
==
'1'
||
record
.
outerStatus
==
'3'
||
record
.
outerStatus
==
'5'
?
<
span
style=
{
{
color
:
'#00B37A'
,
cursor
:
'pointer'
,
marginRight
:
10
}
}
onClick=
{
()
=>
edit
(
record
)
}
>
修改
</
span
>
:
''
}
...
...
@@ -141,12 +142,12 @@ const addList = () => {
cancelText=
"否"
>
<
Button
style=
{
{
marginRight
:
10
}
}
// style=
{{
margin
:
10
}}
type=
"link"
>
删除
</
Button
>
</
Popconfirm
>
}
<
span
style=
{
{
color
:
'#00B37A'
,
cursor
:
'pointer'
,
marginRight
:
10
}
}
onClick=
{
()
=>
submit
(
record
.
id
)
}
>
提交
</
span
>
</
div
>
)
}
...
...
src/pages/contract/manage/add/components/FormList.tsx
View file @
252817f1
...
...
@@ -136,14 +136,13 @@ const FormList = (props: any) => {
bidCount
:
sourceType
==
'1'
?
item
.
awardTaxProbability
*
item
.
purchaseCount
/
100
:
sourceType
==
'2'
?
item
.
awardTenderRatio
*
item
.
inviteTenderMateriel
.
count
/
100
:
item
.
purchaseCount
,
bidAmount
:
sourceType
==
'1'
?
item
.
awardTaxProbability
*
item
.
purchaseCount
/
100
*
item
.
taxUnitPrice
:
sourceType
==
'2'
?
item
.
awardTenderRatio
*
item
.
inviteTenderMateriel
.
count
/
100
*
item
.
price
:
item
.
price
,
// productBrand
associatedType
:
_filter
(
sourceType
,
item
,
[
''
,
'productAttributeJson'
,
''
,
''
]).
split
(
'-'
)[
1
],
associatedBrand
:
_filter
(
sourceType
,
item
,
[
''
,
'productBrand'
,
''
,
''
]),
associatedDataId
:
_filter
(
sourceType
,
item
,
[
''
,
'productId'
,
'commoditySkuId'
]),
// 关联商品id
associatedMaterielNo
:
_filter
(
sourceType
,
item
,
[
''
,
'number'
,
'commodityAttribute'
]),
// 关联物料编号
associatedGoods
:
_filter
(
sourceType
,
item
,
[
''
,
'productAttributeJson'
,
'commodityAttribute'
,
''
]),
//关联
associatedMaterielNo
:
_filter
(
sourceType
,
item
,
[
''
,
'number'
,
'commodityCode'
]),
// 关联物料编号
associatedMaterielName
:
_filter
(
sourceType
,
item
,
[
''
,
'productName'
,
'commodityName'
]),
// 关联商品名称
associated
Goods
:
_filter
(
sourceType
,
item
,
[
''
,
'productAttributeJson'
,
'commodityBrand'
]),
//关联品牌
// associatedMaterielName: sourceType == '1' ? item.productName : sourceType == '2' ? item.commodityName : '',
// associatedGoods: sourceType == '1' ? item.productAttributeJson : sourceType == '2' ? item.commodityBrand : ''
,// 关联品牌
associated
Type
:
_filter
(
sourceType
,
item
,
[
''
,
'productAttributeJson'
,
'commodityCategory'
,
''
]).
split
(
'-'
)[
1
],
//规格型号
associatedCategory
:
_filter
(
sourceType
,
item
,
[
''
,
'productAttributeJson'
,
'commodityCategory'
,
''
]),
// 关联商品品类
associatedBrand
:
_filter
(
sourceType
,
item
,
[
''
,
'productBrand'
,
'commodityBrand'
,
''
])
,
// 关联品牌
rowId
:
index
,
}
})
...
...
@@ -358,7 +357,7 @@ const FormList = (props: any) => {
</
div
>
<
div
className=
{
styles
.
text
}
>
<
p
>
规格:
{
record
.
associatedGoods
}
</
p
>
<
p
>
品类:
{
record
.
associated
Type
}
</
p
>
<
p
>
品类:
{
record
.
associated
Category
}
</
p
>
</
div
>
<
div
className=
{
styles
.
text
}
>
<
p
>
品牌:
{
record
.
associatedBrand
}
</
p
>
...
...
src/pages/contract/manage/details/index.tsx
View file @
252817f1
...
...
@@ -292,10 +292,10 @@ const Details = (props: any) => {
</
div
>
<
div
className=
{
style
.
text
}
>
<
p
>
商品编号:
{
record
.
associatedMaterielNo
}
</
p
>
<
p
className=
{
style
.
nowrap
}
>
商品名称:
{
record
.
associated
Goods
}
</
p
>
<
p
className=
{
style
.
nowrap
}
>
商品名称:
{
record
.
associated
MaterielName
}
</
p
>
</
div
>
<
div
className=
{
style
.
text
}
>
<
p
>
规格型号:
{
record
.
associated
Type
}
</
p
>
<
p
>
规格型号:
{
record
.
associated
Goods
}
</
p
>
<
p
>
品类:
{
record
.
associatedCategory
}
</
p
>
</
div
>
<
div
className=
{
style
.
text
}
>
...
...
src/pages/home/components/UserCenter/index.tsx
View file @
252817f1
...
...
@@ -16,6 +16,7 @@ import Icon, { QuestionCircleOutlined } from '@ant-design/icons';
import
{
ReactComponent
as
DefaultAvatar
}
from
'@/assets/imgs/default_avatar.svg'
;
import
UploadFiles
from
'@/components/UploadFiles/UploadFiles'
import
{
UploadChangeParam
}
from
'antd/lib/upload/interface'
import
{
GlobalConfig
}
from
'@/global/config'
;
interface
Iprops
{}
...
...
@@ -74,7 +75,7 @@ const UserCenter: React.FC<Iprops> = (props) => {
<
div
className=
{
styles
.
header
}
>
<
div
className=
{
styles
.
infos
}
>
<
div
className=
{
styles
.
hi
}
>
{
`Hi, ${userAuth?.name}! 欢迎来到
数商云瓴犀业务中台能力中心
`
}
{
`Hi, ${userAuth?.name}! 欢迎来到
${GlobalConfig.global.siteInfo.name}
`
}
</
div
>
<
div
className=
{
styles
.
date
}
>
{
today
.
format
(
'YYYY年MM月DD日'
)
}
星期
{
WEEKDAYS
[
today
.
day
()]
}
...
...
src/pages/member/memberPrVerifyComingData/components/VerifyComingDataDrawer/index.tsx
View file @
252817f1
...
...
@@ -38,6 +38,10 @@ export type ValueType = {
* 审核原因
*/
reason
:
string
,
/**
* 上级id
*/
upperRelationId
:
number
,
}
interface
IProps
{
...
...
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