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
c7c7b795
Commit
c7c7b795
authored
Dec 27, 2022
by
dragondean@qq.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
制作提单的时候生成pdf
parent
38c188e8
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
54 additions
and
10 deletions
+54
-10
package.json
package.json
+3
-2
App.vue
src/App.vue
+5
-0
index.vue
src/views/ecw/box/ladingBill/index.vue
+1
-1
makeLadingBill.vue
src/views/ecw/box/ladingBill/makeLadingBill.vue
+41
-3
tpl.js
src/views/ecw/warehouse/tpl.js
+4
-4
No files found.
package.json
View file @
c7c7b795
...
@@ -42,6 +42,7 @@
...
@@ -42,6 +42,7 @@
"dependencies"
:
{
"dependencies"
:
{
"
@babel/parser
"
:
"
^7.7.4
"
,
"
@babel/parser
"
:
"
^7.7.4
"
,
"
@riophae/vue-treeselect
"
:
"
0.4.0
"
,
"
@riophae/vue-treeselect
"
:
"
0.4.0
"
,
"
@vue/runtime-dom
"
:
"
latest
"
,
"
axios
"
:
"
0.24.0
"
,
"
axios
"
:
"
0.24.0
"
,
"
bpmn-js-token-simulation
"
:
"
^0.10.0
"
,
"
bpmn-js-token-simulation
"
:
"
^0.10.0
"
,
"
clipboard
"
:
"
2.0.8
"
,
"
clipboard
"
:
"
2.0.8
"
,
...
@@ -58,6 +59,7 @@
...
@@ -58,6 +59,7 @@
"
js-beautify
"
:
"
1.13.0
"
,
"
js-beautify
"
:
"
1.13.0
"
,
"
js-cookie
"
:
"
3.0.1
"
,
"
js-cookie
"
:
"
3.0.1
"
,
"
jsencrypt
"
:
"
3.0.0-rc.1
"
,
"
jsencrypt
"
:
"
3.0.0-rc.1
"
,
"
jspdf
"
:
"
^2.5.1
"
,
"
min-dash
"
:
"
^3.5.2
"
,
"
min-dash
"
:
"
^3.5.2
"
,
"
nprogress
"
:
"
0.2.0
"
,
"
nprogress
"
:
"
0.2.0
"
,
"
number-precision
"
:
"
^1.5.2
"
,
"
number-precision
"
:
"
^1.5.2
"
,
...
@@ -77,8 +79,7 @@
...
@@ -77,8 +79,7 @@
"
vuedraggable
"
:
"
2.24.3
"
,
"
vuedraggable
"
:
"
2.24.3
"
,
"
vuex
"
:
"
3.6.0
"
,
"
vuex
"
:
"
3.6.0
"
,
"
xlsx
"
:
"
^0.18.5
"
,
"
xlsx
"
:
"
^0.18.5
"
,
"
xml-js
"
:
"
^1.6.11
"
,
"
xml-js
"
:
"
^1.6.11
"
"
@vue/runtime-dom
"
:
"
latest
"
},
},
"devDependencies"
:
{
"devDependencies"
:
{
"
@vue/cli-plugin-babel
"
:
"
4.4.6
"
,
"
@vue/cli-plugin-babel
"
:
"
4.4.6
"
,
...
...
src/App.vue
View file @
c7c7b795
...
@@ -81,4 +81,9 @@ $sizes: 0, 10,20,30,50,100,150,200,300,500,800,1000;
...
@@ -81,4 +81,9 @@ $sizes: 0, 10,20,30,50,100,150,200,300,500,800,1000;
width
:
#{
$item
}
px
!
important
;
width
:
#{
$item
}
px
!
important
;
}
}
}
}
table
{
border-collapse
:
collapse
;
border-spacing
:
0
;
}
</
style
>
</
style
>
src/views/ecw/box/ladingBill/index.vue
View file @
c7c7b795
...
@@ -204,7 +204,7 @@ export default {
...
@@ -204,7 +204,7 @@ export default {
}
}
this
.
currRow
=
row
;
this
.
currRow
=
row
;
this
.
$set
(
this
.
dialogCfg
,
"
type
"
,
type
);
this
.
$set
(
this
.
dialogCfg
,
"
type
"
,
type
);
this
.
$set
(
this
.
dialogCfg
,
"
width
"
,
"
1
0
00px
"
);
this
.
$set
(
this
.
dialogCfg
,
"
width
"
,
"
1
2
00px
"
);
this
.
$set
(
this
.
dialogCfg
,
"
visible
"
,
true
);
this
.
$set
(
this
.
dialogCfg
,
"
visible
"
,
true
);
},
},
makeBill
(
row
)
{
makeBill
(
row
)
{
...
...
src/views/ecw/box/ladingBill/makeLadingBill.vue
View file @
c7c7b795
...
@@ -19,11 +19,16 @@
...
@@ -19,11 +19,16 @@
<el-button
plain
type=
"primary"
@
click=
"showLoaingTemplate"
>
{{
$t
(
'
提单预览
'
)
}}
</el-button>
<el-button
plain
type=
"primary"
@
click=
"showLoaingTemplate"
>
{{
$t
(
'
提单预览
'
)
}}
</el-button>
</div>
</div>
<div
v-if=
"currRow.status !== 1"
>
<div
v-if=
"currRow.status !== 1"
>
<el-button
type=
"primary"
@
click=
"
submit
"
>
{{
$t
(
'
提交审核
'
)
}}
</el-button>
<el-button
type=
"primary"
@
click=
"
createPdf
"
>
{{
$t
(
'
提交审核
'
)
}}
</el-button>
<el-button
type=
"primary"
@
click=
"showLoaingTemplate"
>
{{
$t
(
'
提单预览
'
)
}}
</el-button>
<el-button
type=
"primary"
@
click=
"showLoaingTemplate"
>
{{
$t
(
'
提单预览
'
)
}}
</el-button>
</div>
</div>
</el-row>
</el-row>
<!-- htm2canvas 容器 -->
<div
style=
"height:0; overflow: hidden;"
>
<div
id=
"html2canvas-container"
v-html=
"billContent"
></div>
</div>
<el-dialog
:title=
"dialogCfg.title"
:visible.sync=
"visible"
width=
"1000px"
append-to-body
class=
"shippingSea-dialog"
>
<el-dialog
:title=
"dialogCfg.title"
:visible.sync=
"visible"
width=
"1000px"
append-to-body
class=
"shippingSea-dialog"
>
<previewBill
v-if=
"visible"
:contentHtml=
"billContent"
:currRow=
"currRow"
:type=
"dialogCfg.type"
/>
<previewBill
v-if=
"visible"
:contentHtml=
"billContent"
:currRow=
"currRow"
:type=
"dialogCfg.type"
/>
</el-dialog>
</el-dialog>
...
@@ -41,7 +46,9 @@ import {
...
@@ -41,7 +46,9 @@ import {
import
{
serviceMsg
,
toReviewDetail
}
from
"
../shippingSea/utils
"
;
import
{
serviceMsg
,
toReviewDetail
}
from
"
../shippingSea/utils
"
;
import
previewBill
from
"
./previewBill.vue
"
;
import
previewBill
from
"
./previewBill.vue
"
;
import
{
getToken
}
from
"
@/utils/auth
"
;
import
{
getToken
}
from
"
@/utils/auth
"
;
import
html2canvas
from
'
html2canvas
'
;
import
{
jsPDF
}
from
"
jspdf
"
;
import
{
uploadFile
}
from
'
@/api/infra/file
'
export
default
{
export
default
{
name
:
"
makeLadingBill
"
,
name
:
"
makeLadingBill
"
,
components
:
{
components
:
{
...
@@ -165,8 +172,34 @@ export default {
...
@@ -165,8 +172,34 @@ export default {
showLoaingTemplate
()
{
showLoaingTemplate
()
{
this
.
visible
=
true
;
this
.
visible
=
true
;
},
},
submit
()
{
createPdf
(){
let
loading
=
this
.
$loading
()
html2canvas
(
document
.
querySelector
(
"
#html2canvas-container
"
),
{
dpi
:
144
}).
then
(
canvas
=>
{
const
doc
=
new
jsPDF
(
'
p
'
,
'
pt
'
,
'
a4
'
,
true
);
const
imgWidth
=
canvas
.
width
const
imgHeight
=
canvas
.
height
let
_w
=
595.28
;
let
_h
=
595.28
/
imgWidth
*
imgHeight
;
if
(
_h
>
841.89
){
_h
=
841.89
;
_w
=
_h
/
imgHeight
*
imgWidth
}
const
_left
=
(
595.28
-
_w
)
/
2
;
doc
.
addImage
(
canvas
,
'
PNG
'
,
_left
,
0
,
_w
,
_h
,
''
,
'
FAST
'
);
// doc.save("a4.pdf");
let
form
=
new
FormData
()
form
.
append
(
'
file
'
,
new
File
([
doc
.
output
(
'
arraybuffer
'
)],
Date
.
now
()
+
'
.pdf
'
,
{
type
:
'
application/pdf
'
}))
return
uploadFile
(
form
)
}).
then
(
res
=>
{
return
this
.
submit
(
res
.
data
)
}).
finally
(
res
=>
{
loading
.
close
()
})
},
submit
(
imgUrl
)
{
let
params
=
{
let
params
=
{
imgUrl
,
billContent
:
this
.
billContent
,
billContent
:
this
.
billContent
,
orderId
:
this
.
currRow
.
orderId
,
orderId
:
this
.
currRow
.
orderId
,
copyUserId
:
this
.
selectedUsers
,
copyUserId
:
this
.
selectedUsers
,
...
@@ -219,6 +252,11 @@ export default {
...
@@ -219,6 +252,11 @@ export default {
</
script
>
</
script
>
<
style
lang=
"scss"
scoped
>
<
style
lang=
"scss"
scoped
>
::v-deep
#html2canvas-container
{
p
{
margin
:
0
;
}
}
.shipping-makeLadingBill
{
.shipping-makeLadingBill
{
.title-orderNo
{
.title-orderNo
{
text-align
:
center
;
text-align
:
center
;
...
...
src/views/ecw/warehouse/tpl.js
View file @
c7c7b795
const
sea
=
`
const
sea
=
`
<table style="width:
96
%;">
<table style="width:
100
%;">
<tbody>
<tbody>
...
@@ -59,7 +59,7 @@ const sea = `
...
@@ -59,7 +59,7 @@ const sea = `
</tbody>
</tbody>
</table>
</table>
<table style="width:
96
%;">
<table style="width:
100
%;">
<tbody>
<tbody>
...
@@ -96,7 +96,7 @@ const sea = `
...
@@ -96,7 +96,7 @@ const sea = `
`
`
const
air
=
`
const
air
=
`
<table style="width:
96
%;">
<table style="width:
100
%;">
<tbody>
<tbody>
<tr class="firstRow">
<tr class="firstRow">
<td style="text-align:center;">
<td style="text-align:center;">
...
@@ -146,7 +146,7 @@ const air= `
...
@@ -146,7 +146,7 @@ const air= `
</tr>
</tr>
</tbody>
</tbody>
</table>
</table>
<table style="width:
96
%;">
<table style="width:
100
%;">
<tbody>
<tbody>
<tr class="firstRow">
<tr class="firstRow">
<td style="font-size:16px;color:#008fd7;font-family:'Times New Roman';text-align:center;">
<td style="font-size:16px;color:#008fd7;font-family:'Times New Roman';text-align:center;">
...
...
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