Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
jiedao-app-operator-master
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
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
lanbaoming
jiedao-app-operator-master
Commits
01195b03
Commit
01195b03
authored
Oct 13, 2022
by
Marcus
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/dev' into dev
parents
4b34031a
60ece7c1
Changes
10
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
331 additions
and
262 deletions
+331
-262
done.vue
src/views/bpm/task/done.vue
+29
-8
todo.vue
src/views/bpm/task/todo.vue
+27
-27
edit.vue
src/views/ecw/coupon/edit.vue
+158
-153
printVoucher.vue
src/views/ecw/financial/printVoucher.vue
+84
-39
receiptDetail.vue
src/views/ecw/financial/receiptDetail.vue
+7
-5
receivable.vue
src/views/ecw/financial/receivable.vue
+0
-9
edit.vue
src/views/ecw/order/edit.vue
+1
-1
batchEdit.vue
src/views/ecw/productPrice/batchEdit.vue
+15
-5
edit.vue
src/views/ecw/productPrice/edit.vue
+8
-13
index.vue
src/views/ecw/warehouse/index.vue
+2
-2
No files found.
src/views/bpm/task/done.vue
View file @
01195b03
...
...
@@ -5,10 +5,24 @@
<el-form-item
:label=
"$t('任务名称')"
prop=
"name"
>
<el-input
v-model=
"queryParams.name"
:placeholder=
"$t('请输入任务名称')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
</el-form-item>
<el-form-item
:label=
"$t('创建时间')"
>
<el-form-item
:label=
"$t('流程编号')"
prop=
"name"
>
<!--// TODO 缺少查询字段-->
<!--
<el-input
v-model=
"queryParams.no"
:placeholder=
"$t('请输入流程编号')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
-->
缺少字段
</el-form-item>
<el-form-item
:label=
"$t('流程分类')"
prop=
"name"
>
<!--// TODO 缺少查询字段-->
<!--
<el-input
v-model=
"queryParams.no"
:placeholder=
"$t('请输入流程编号')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
-->
缺少字段
</el-form-item>
<el-form-item
:label=
"$t('提交时间')"
>
<el-date-picker
v-model=
"dateRangeCreateTime"
style=
"width: 240px"
value-format=
"yyyy-MM-dd"
type=
"daterange"
range-separator=
"-"
:start-placeholder=
"$t('开始日期')"
:end-placeholder=
"$t('结束日期')"
/>
</el-form-item>
<el-form-item
:label=
"$t('业务编号')"
prop=
"name"
>
缺少字段
</el-form-item>
<el-form-item>
<el-button
type=
"primary"
icon=
"el-icon-search"
@
click=
"handleQuery"
>
{{
$t
(
'
搜索
'
)
}}
</el-button>
<el-button
icon=
"el-icon-refresh"
@
click=
"resetQuery"
>
{{
$t
(
'
重置
'
)
}}
</el-button>
...
...
@@ -18,30 +32,37 @@
<!-- 列表 -->
<el-table
v-loading=
"loading"
:data=
"list"
>
<el-table-column
:label=
"$t('任务编号')"
align=
"center"
prop=
"id"
width=
"320"
fixed
/>
<el-table-column
:label=
"$t('任务名称')"
align=
"center"
prop=
"name"
width=
"200"
/>
<el-table-column
:label=
"$t('所属流程')"
align=
"center"
prop=
"processInstance.name"
width=
"200"
/>
<el-table-column
:label=
"$t('任务名称')"
align=
"center"
prop=
"processInstance.name"
width=
"200"
/>
<el-table-column
:label=
"$t('业务编号')"
align=
"center"
prop=
""
width=
"200"
>
缺少字段
</el-table-column>
<el-table-column
:label=
"$t('流程分类')"
align=
"center"
prop=
"category"
width=
"200"
/>
<el-table-column
:label=
"$t('当前审批节点')"
align=
"center"
prop=
"name"
width=
"200"
/>
<el-table-column
:label=
"$t('状态')"
align=
"center"
prop=
""
width=
"200"
>
缺少字段
</el-table-column>
<el-table-column
:label=
"$t('流程发起人')"
align=
"center"
prop=
"processInstance.startUserNickname"
width=
"120"
/>
<el-table-column
:label=
"$t('结果')"
align=
"center"
prop=
"result"
>
<template
slot-scope=
"scope"
>
<dict-tag
:type=
"DICT_TYPE.BPM_PROCESS_INSTANCE_RESULT"
:value=
"scope.row.result"
/>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('审批意见')"
align=
"center"
prop=
"comment"
width=
"200"
/
>
<el-table-column
:label=
"$t('
创建
时间')"
align=
"center"
prop=
"createTime"
width=
"180"
>
<!-- <el-table-column :label="$t('审批意见')" align="center" prop="comment" width="200" />--
>
<el-table-column
:label=
"$t('
提交
时间')"
align=
"center"
prop=
"createTime"
width=
"180"
>
<
template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
createTime
)
}}
</span>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('
审批
时间')"
align=
"center"
prop=
"endTime"
width=
"180"
>
<el-table-column
:label=
"$t('
结束
时间')"
align=
"center"
prop=
"endTime"
width=
"180"
>
<
template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
endTime
)
}}
</span>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('耗时')"
align=
"center"
prop=
"durationInMillis"
width=
"180"
>
<!--
<el-table-column :label="$t('耗时')" align="center" prop="durationInMillis" width="180">
<template slot-scope="scope">
<span>{{ getDateStar(scope.row.durationInMillis) }}</span>
</template>
</el-table-column>
</el-table-column>
-->
<el-table-column
:label=
"$t('操作')"
align=
"center"
fixed=
"right"
class-name=
"small-padding fixed-width"
>
<
template
slot-scope=
"scope"
>
<el-button
size=
"mini"
type=
"text"
icon=
"el-icon-edit"
@
click=
"handleAudit(scope.row)"
...
...
src/views/bpm/task/todo.vue
View file @
01195b03
...
...
@@ -2,37 +2,28 @@
<div
class=
"app-container"
>
<!-- 搜索工作栏 -->
<el-form
:model=
"queryParams"
ref=
"queryForm"
size=
"small"
:inline=
"true"
v-show=
"showSearch"
label-width=
"68px"
>
<el-form-item
:label=
"$t('
任务名称
')"
prop=
"name"
>
<el-input
v-model=
"queryParams.name"
:placeholder=
"$t('请输入
任务
名')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
<el-form-item
:label=
"$t('
流程名
')"
prop=
"name"
>
<el-input
v-model=
"queryParams.name"
:placeholder=
"$t('请输入
流程
名')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
</el-form-item>
<!-- // TODO 接口暂不支持
<el-form-item
label=
"流程编号"
prop=
"name"
>
<el-input
v-model=
"queryParams.name"
placeholder=
"请输入流程编号"
clearable
@
keyup.enter.native=
"handleQuery"
/>
<el-form-item
label=
"编号"
prop=
"name"
>
缺少字段
</el-form-item>
-->
<el-form-item
:label=
"$t('流程分类')"
prop=
"category"
>
<el-select
v-model=
"queryParams.category"
:placeholder=
"$t('请选择流程分类')"
clearable
>
<el-option
v-for=
"dict in this.getDictDatas(DICT_TYPE.BPM_MODEL_CATEGORY)"
:key=
"dict.value"
:label=
"dict.label"
:value=
"dict.value"
/>
</el-select>
</el-form-item>
<el-form-item
:label=
"$t('提交时间')"
>
<el-date-picker
v-model=
"dateRangeCreateTime"
style=
"width: 240px"
value-format=
"yyyy-MM-dd"
type=
"daterange"
range-separator=
"-"
:start-placeholder=
"$t('开始日期')"
:end-placeholder=
"$t('结束日期')"
/>
</el-form-item>
<!-- // TODO 接口暂不支持
<el-form-item
label=
"状态"
prop=
"name"
>
</el-form-item>
<el-form-item
label=
"结果"
prop=
"name"
>
</el-form-item>
-->
<el-form-item
:label=
"$t('业务编码')"
prop=
"businessNo"
>
<el-input
v-model=
"queryParams.businessNo"
:placeholder=
"$t('请输入业务编码')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
<el-form-item
:label=
"$t('业务编号')"
prop=
"businessNo"
>
<el-input
v-model=
"queryParams.businessNo"
:placeholder=
"$t('请输入业务编号')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
</el-form-item>
<el-form-item>
<el-button
type=
"primary"
icon=
"el-icon-search"
@
click=
"handleQuery"
>
{{
$t
(
'
搜索
'
)
}}
</el-button>
<el-button
icon=
"el-icon-refresh"
@
click=
"resetQuery"
>
{{
$t
(
'
重置
'
)
}}
</el-button>
...
...
@@ -41,25 +32,34 @@
<!-- 列表 -->
<el-table
v-loading=
"loading"
:data=
"list"
>
<el-table-column
:label=
"$t('
任务
编号')"
align=
"center"
prop=
"id"
width=
"320"
/>
<el-table-column
:label=
"$t('
业务编号')"
align=
"center"
prop=
"businessNo
"
/>
<el-table-column
:label=
"$t('编号')"
align=
"center"
prop=
"id"
width=
"320"
/>
<el-table-column
:label=
"$t('
流程名称')"
align=
"center"
prop=
"processInstance.name"
width=
"320
"
/>
<el-table-column
:label=
"$t('流程分类')"
align=
"center"
prop=
"category"
>
<template
slot-scope=
"scope"
>
<dict-tag
:type=
"DICT_TYPE.BPM_MODEL_CATEGORY"
:value=
"scope.row.category"
/>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('所属流程')"
align=
"center"
prop=
"processInstance.name"
/>
<el-table-column
:label=
"$t('当前审批任务')"
align=
"center"
prop=
"name"
/>
<el-table-column
:label=
"$t('流程发起人')"
align=
"center"
prop=
"processInstance.startUserNickname"
/>
<el-table-column
:label=
"$t('创建时间')"
align=
"center"
prop=
"createTime"
width=
"180"
>
<el-table-column
:label=
"$t('业务编号')"
align=
"center"
prop=
"businessNo"
/>
<el-table-column
:label=
"$t('当前审批节点')"
align=
"center"
prop=
"name"
/>
<el-table-column
:label=
"$t('状态')"
align=
"center"
prop=
"version"
width=
"80"
>
<
template
slot-scope=
"scope"
>
<el-tag
type=
"success"
v-if=
"scope.row.suspensionState === 1"
>
{{
$t
(
'
激活
'
)
}}
</el-tag>
<el-tag
type=
"warning"
v-if=
"scope.row.suspensionState === 2"
>
{{
$t
(
'
挂起
'
)
}}
</el-tag>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('结果')"
align=
"center"
prop=
"processInstance.startUserNickname"
>
缺少字段
</el-table-column>
<el-table-column
:label=
"$t('提交时间')"
align=
"center"
prop=
"createTime"
width=
"180"
>
<
template
slot-scope=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
createTime
)
}}
</span>
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('
状态')"
align=
"center"
prop=
"version"
width=
"
80"
>
<el-table-column
:label=
"$t('
结束时间')"
align=
"center"
prop=
"createTime"
width=
"1
80"
>
<
template
slot-scope=
"scope"
>
<el-tag
type=
"success"
v-if=
"scope.row.suspensionState === 1"
>
{{
$t
(
'
激活
'
)
}}
</el-tag>
<el-tag
type=
"warning"
v-if=
"scope.row.suspensionState === 2"
>
{{
$t
(
'
挂起
'
)
}}
</el-tag>
缺少字段
</
template
>
</el-table-column>
<el-table-column
:label=
"$t('操作')"
align=
"center"
class-name=
"small-padding fixed-width"
>
...
...
src/views/ecw/coupon/edit.vue
View file @
01195b03
This diff is collapsed.
Click to expand it.
src/views/ecw/financial/printVoucher.vue
View file @
01195b03
This diff is collapsed.
Click to expand it.
src/views/ecw/financial/receiptDetail.vue
View file @
01195b03
...
...
@@ -260,22 +260,24 @@
<
/template
>
{{
form
.
receivableTotalAmount
}}
<
/el-descriptions-item> --
>
<
el
-
descriptions
-
item
:
label
=
"
$t('已核销总金额')
"
>
<
el
-
tag
>
{{
verificationData
.
usCount
}}
{{
$t
(
'
美元
'
)
}}
<
/el-tag
>
<
el
-
tag
>
{{
verificationData
.
rmbCount
}}
{{
$t
(
'
人民币
'
)
}}
<
/el-tag
>
<
el
-
tag
>
{{
verificationData
.
nairaCount
}}
{{
$t
(
'
奈拉
'
)
}}
<
/el-tag
>
<
el
-
tag
>
{{
verificationData
.
usCount
.
toFixed
(
6
)
}}
{{
$t
(
'
美元
'
)
}}
<
/el-tag
>
<
el
-
tag
>
{{
verificationData
.
rmbCount
.
toFixed
(
6
)
}}
{{
$t
(
'
人民币
'
)
}}
<
/el-tag
>
<
el
-
tag
>
{{
verificationData
.
nairaCount
.
toFixed
(
6
)
}}
{{
$t
(
'
奈拉
'
)
}}
<
/el-tag
>
<
/el-descriptions-item
>
<
el
-
descriptions
-
item
>
<
template
slot
=
"
label
"
>
{{
$t
(
'
已核销金额
'
)
}}
(
<
dict
-
tag
:
type
=
"
DICT_TYPE.BOX_SHIPPING_PRICE_UNIT
"
:
value
=
"
showCurrencyId
"
/>
)
<
/template
>
{{
verificationData
.
writtenOff
}}
{{
verificationData
.
writtenOff
.
toFixed
(
6
)
}}
<
/el-descriptions-item
>
<
el
-
descriptions
-
item
>
<
template
slot
=
"
label
"
>
{{
$t
(
'
已核销比例
'
)
}}
(
<
dict
-
tag
:
type
=
"
DICT_TYPE.BOX_SHIPPING_PRICE_UNIT
"
:
value
=
"
showCurrencyId
"
/>
)
<
/template
>
{{
verificationData
.
WriteOffProportion
}}
%
{{
parseFloat
(
verificationData
.
WriteOffProportion
/
100
).
toFixed
(
2
)
}}
%
<
/el-descriptions-item
>
<
/el-descriptions
>
<
/el-card
>
...
...
src/views/ecw/financial/receivable.vue
View file @
01195b03
...
...
@@ -162,15 +162,6 @@
clearable
/>
</el-form-item>
<el-form-item
:label=
"$t('自编号')"
>
<el-input
style=
"max-width: 188px"
v-model=
"queryParams.selfNo"
:placeholder=
"$t('请输入自编号')"
clearable
@
keyup.enter.native=
"handleQuery"
/>
</el-form-item>
<el-form-item
:label=
"$t('创建时间')"
>
<!--
<dict-selector
:type=
"DICT_TYPE.BEGINTIME_TYPE_ENDTIME"
v-model=
"queryParams.date"
></dict-selector>
-->
<el-date-picker
...
...
src/views/ecw/order/edit.vue
View file @
01195b03
...
...
@@ -290,7 +290,7 @@
</el-form-item>
</div>
<div>
<el-form-item
:label=
"$t('外部仓库')"
prop=
"
warehouseTyp
e"
>
<el-form-item
:label=
"$t('外部仓库')"
prop=
"
isExternalWarehous
e"
>
<el-checkbox
label=
""
:checked=
"!!form.isExternalWarehouse"
@
change=
"form.isExternalWarehouse=$event"
:disabled=
"false"
></el-checkbox>
</el-form-item>
<div
v-if=
"form.isExternalWarehouse"
class=
"pl-50"
>
...
...
src/views/ecw/productPrice/batchEdit.vue
View file @
01195b03
...
...
@@ -2,7 +2,7 @@
<div
class=
"app-container"
>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"150px"
>
<products-selector
v-model=
"form.productIdList"
class=
"mb-20"
/>
<routers-selector
v-model=
"selectedRoutes"
/>
<el-card
style=
"margin-bottom: 10px"
>
...
...
@@ -90,7 +90,7 @@
<
/el-row
>
<
/el-form-item
>
<
/template
>
<!--
特需
-->
<
template
v
-
if
=
"
form.priceType==1
"
>
...
...
@@ -154,6 +154,11 @@
<!--
<
el
-
form
-
item
label
=
"
是否预付
"
prop
=
"
advanceStatus
"
>
<
dict
-
selector
form
-
type
=
"
radio
"
:
type
=
"
DICT_TYPE.ADVANCE_STATUS
"
v
-
model
=
"
form.advanceStatus
"
/>
<
/el-form-item> --
>
<
el
-
form
-
item
:
label
=
"
$t('价格有效期')
"
>
<
el
-
date
-
picker
v
-
model
=
"
form.validateStartDate
"
value
-
format
=
"
yyyy-MM-dd HH:mm:ss
"
><
/el-date-picker
>
-
<
el
-
date
-
picker
v
-
model
=
"
form.validateEndDate
"
value
-
format
=
"
yyyy-MM-dd HH:mm:ss
"
><
/el-date-picker
>
<
/el-form-item
>
<
/el-card
>
...
...
@@ -197,6 +202,7 @@ import ProductsSelector from '@/components/ProductsSelector'
import
{
arrryToKeyedObjectBy
}
from
'
@/utils/index
'
import
Selector
from
'
@/components/Selector
'
import
Inputor
from
'
@/components/Inputor
'
import
{
parseTime
}
from
'
@/utils/ruoyi
'
export
default
{
components
:
{
RoutersSelector
,
ProductsSelector
,
Selector
,
Inputor
}
,
...
...
@@ -306,7 +312,7 @@ export default {
}
}
,
async
created
()
{
/* this.productDisabled = false
// 获取类型列表
...
...
@@ -319,6 +325,10 @@ export default {
this.$set(this.form, 'productId', +this.$route.query.product_id)
}
*/
// 默认今天起,两年有效
this
.
form
.
validateStartDate
=
parseTime
(
Date
.
now
())
this
.
form
.
validateEndDate
=
parseTime
(
Date
.
now
()
+
86400
*
365
*
2
*
1000
)
// 默认费用单位
this
.
setDefaultVolumeUnit
(
7
)
...
...
@@ -364,7 +374,7 @@ export default {
}
data
.
lineChannelList
=
this
.
selectedRoutes
if
(
data
.
lineChannelList
.
length
<
1
){
return
this
.
$message
.
error
(
this
.
$t
(
'
请选择需要修改的路线
'
))
}
...
...
@@ -384,4 +394,4 @@ export default {
.
mr10
{
margin
-
right
:
10
px
;
}
<
/style>
\ No newline at end of file
<
/style
>
src/views/ecw/productPrice/edit.vue
View file @
01195b03
...
...
@@ -127,7 +127,7 @@
<
selector
v
-
model
=
"
form.clearanceVolumeUnit
"
:
options
=
"
unitList
"
:
label
-
field
=
"
$l('title')
"
value
-
field
=
"
id
"
defaultable
class
=
"
w-100
"
/>
<
/el-form-item
>
<
/template
>
<!--
特需
-->
<
template
v
-
if
=
"
form.priceType==1
"
>
...
...
@@ -230,17 +230,9 @@ export default {
priceStepList
:
[{
}
,{
}
],
// 阶梯价格
// specialList:[], // 特殊需求,默认四个
rules
:
{
/* typeId: [{ required: true, message: "产品类型不能为空", trigger: "blur"
}
],
titleZh: [{ required: true, message: "产品名称不能为空", trigger: "blur"
}
],
titleEn: [{ required: true, message: "英文名称不能为空", trigger: "blur"
}
], */
transportPrice
:
[{
required
:
true
,
message
:
this
.
$t
(
"
海运费不能为空
"
),
trigger
:
"
blur
"
}
],
clearancePrice
:
[{
required
:
true
,
message
:
this
.
$t
(
"
清关费不能为空
"
),
trigger
:
"
blur
"
}
],
advanceStatus
:
[{
required
:
true
,
message
:
this
.
$t
(
"
是否预付不能为空
"
),
trigger
:
"
blur
"
}
],
//containerLocation: [
{
required
:
true
,
message
:
"
货柜位置不能为空
"
,
trigger
:
"
blur
"
}
],
//square: [
{
required
:
true
,
message
:
"
方数不能为空
"
,
trigger
:
"
blur
"
}
],
// zhongLinjie:[
{
required
:
true
,
message
:
"
默认重货标准不能为空
"
,
trigger
:
"
blur
"
}
],
// paoLinjie:[
{
required
:
true
,
message
:
"
默认泡货标准不能为空
"
,
trigger
:
"
blur
"
}
],
// needBook: [
{
required
:
true
,
message
:
"
预约入仓不能为空
"
,
trigger
:
"
blur
"
}
],
advanceStatus
:
[{
required
:
true
,
message
:
this
.
$t
(
"
是否预付不能为空
"
),
trigger
:
"
blur
"
}
]
}
,
product
:
null
,
/* productType: null, */
...
...
@@ -274,7 +266,7 @@ export default {
this
.
$set
(
this
.
form
,
'
square
'
,
this
.
product
.
square
)
this
.
$set
(
this
.
form
,
'
dayLimit
'
,
this
.
product
.
dayLimit
)
this
.
$set
(
this
.
form
,
'
containerLocation
'
,
this
.
product
.
containerLocation
)
}
,
form
(
val
)
{
if
(
!
val
)
return
...
...
@@ -375,6 +367,9 @@ export default {
}
getProductPriceList
(
query
).
then
(
res
=>
{
this
.
lineList
=
res
.
data
this
.
lineList
.
forEach
(
item
=>
{
this
.
checkList
.
push
(
item
.
id
)
}
)
}
)
}
...
...
@@ -382,7 +377,7 @@ export default {
if
(
!
this
.
$route
.
query
.
product_id
){
this
.
productDisabled
=
false
}
// 获取类型列表
getProductTypeList
().
then
(
res
=>
this
.
productTypeList
=
res
.
data
)
...
...
@@ -516,4 +511,4 @@ export default {
.
mr10
{
margin
-
right
:
10
px
;
}
<
/style>
\ No newline at end of file
<
/style
>
src/views/ecw/warehouse/index.vue
View file @
01195b03
...
...
@@ -566,7 +566,7 @@ export default {
for
(
let
index
in
transportTypes
)
{
let
transportType
=
transportTypes
[
index
];
let
name
=
this
.
transportName
(
transportType
);
names
.
push
(
name
);
if
(
name
)
names
.
push
(
name
);
}
return
names
.
join
(
'
,
'
);
}
...
...
@@ -855,7 +855,7 @@ export default {
this
.
destName
=
row
.
titleZh
;
}
this
.
getRouteList
();
},
...
...
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