SealTemplateWrap.js
13.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import React,{PropTypes} from 'react';
import cx from 'classnames';
import {
message,
} from 'antd';
class SealTemplateWrap extends React.Component {
constructor(props) {
super(props)
this.setSeal = this.setSeal.bind(this);
this.js_getDPI = this.js_getDPI.bind(this);
this.px2pt = this.px2pt.bind(this);
this.changePXY = this.changePXY.bind(this);
this.state = {
}
}
static propTypes = {
template: PropTypes.string,
onChange:PropTypes.func,
sealImg:PropTypes.string
}
static defaultProps = {
template:'<p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">离职证明</p><p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">某某先生/女士/小姐自XX年01月01日入职我公司担任人力资源部人力资源助理职务,至2011年07月31日因个人原因申请离职,在此间无不良表现,经公司研究决定,同意其离职,已办理离职手续。</p><p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">因未签订相关保密协议,遵从择业自由。</p><p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">特此证明</p><p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">公司名称(加盖<a class="custom_field_seal" data-field="签章位置" data-field-type="seal" data-field-system="1" data-field-owner="1" style="background-color: rgb(255, 255, 255); font-family: BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 12px;"> </a><span style="text-indent: 2em;">公章)</span></p><p class="f14 t2 lh26 s-c666 mt10" style="font-family: tahoma, 微软雅黑; margin-top: 10px !important; font-size: 14px !important; text-indent: 2em !important; color: rgb(102, 102, 102) !important;">2011年07月31日</p>',
sealImg:'',
onChange:(top,bottom,left,page)=>{
console.log(top,bottom,left,page);
}
}
componentDidUpdate(){
$('.custom_field_seal', $('#seal_template_wrap')).addClass("hidden_template_seal");
}
js_getDPI(){
const arrDPI = new Array();
if (window.screen.deviceXDPI != undefined) {
arrDPI[0] = window.screen.deviceXDPI;
arrDPI[1] = window.screen.deviceYDPI;
}
else {
const tmpNode = document.createElement("DIV");
tmpNode.style.cssText = "width:1in;height:1in;position:absolute;left:0px;top:0px;z-index:99;visibility:hidden";
document.body.appendChild(tmpNode);
arrDPI[0] = parseInt(tmpNode.offsetWidth);
arrDPI[1] = parseInt(tmpNode.offsetHeight);
tmpNode.parentNode.removeChild(tmpNode);
}
return arrDPI[0];
}
px2pt(px){
const pt = px*72/this.js_getDPI();
return pt;
}
changePXY(top,left){
const arrA4 = new Array();
const tmpNode = document.createElement("DIV");
tmpNode.style.cssText = "width:210mm;height:297mm;position:absolute;left:0px;top:0px;z-index:99;visibility:hidden";
document.body.appendChild(tmpNode);
arrA4[0] = parseInt(tmpNode.offsetWidth);
arrA4[1] = parseInt(tmpNode.offsetHeight);
tmpNode.parentNode.removeChild(tmpNode);
const page = parseInt(top/arrA4[1]);
const pageTop = page==0?top:top-arrA4[1]*page;
const pageBottom = arrA4[1]-pageTop;
return {
pageBottom:this.px2pt(pageBottom),
pageTop:this.px2pt(pageTop),
pageLeft:this.px2pt(left),
page:page+1
}
}
setSeal(){
const { sealImg,onChange } = this.props;
let templateOffset='';
if($('.custom_field_seal',$('#seal_template_wrap'))){
templateOffset = $('.custom_field_seal',$('#seal_template_wrap')).offset();
}else{
return message.error('该证明模板未设置签章位置');
}
const sealOffset = $('#seal_template_wrap').offset();
const top = templateOffset.top-sealOffset.top;
const left = templateOffset.left-sealOffset.left;
const {pageBottom,page,pageTop,pageLeft} = this.changePXY(top,left);
const sealTemplate = `<img id="seal-one" style="width: 4.3cm;position: absolute;transform: translate(-50%, -50%);top:${top}px;left:${left}px;" src="${sealImg}">`;
$('#seal-one',$('#seal_template_wrap')).remove();
$('#seal_template_wrap').append(sealTemplate);
// console.log($('.custom_field_seal',$('#seal_template_wrap')).offset());
// console.log($('#seal_template_wrap').offset());
onChange(pageTop,pageBottom,pageLeft,page);
}
render() {
const { template } = this.props;
return (
<div id={'seal_template_wrap'} dangerouslySetInnerHTML={{__html: `${template}`}} >
</div>
)
}
}
export default SealTemplateWrap;