Files
2025-12-09 20:22:03 +08:00

331 lines
14 KiB
JavaScript

(function (vc) {
vc.extends({
propTypes: {
notifyLoadDataComponentName: vc.propTypes.string,
componentTitle: vc.propTypes.string // 组件名称
},
data: {
addOwnerInfo: {
componentTitle: $props.componentTitle,
name: '',
age: '',
link: '',
address: '',
sex: '',
ownerTypeCd: '',
remark: '',
ownerId: '',
ownerPhoto: '',
ownerPhotoUrl: '',
idCard: '',
cardNumber: '',
videoPlaying: true,
mediaStreamTrack: null,
attrs: []
}
},
_initMethod: function () {
$that._loadOwnerAttrSpec();
},
_initEvent: function () {
vc.on('addOwner', 'openAddOwnerModal', function (_ownerId) {
if (_ownerId != null || _ownerId != -1) {
$that.addOwnerInfo.ownerId = _ownerId;
}
$('#addOwnerModel').modal('show');
$that._initAddOwnerMedia();
});
},
methods: {
addOwnerValidate: function () {
return vc.validate.validate({
addOwnerInfo: $that.addOwnerInfo
}, {
'addOwnerInfo.name': [{
limit: "required",
param: "",
errInfo: "姓名不能为空"
},
{
limit: "maxin",
param: "2,10",
errInfo: "姓名长度必须在2位至10位"
},
],
'addOwnerInfo.link': [{
limit: "required",
param: "",
errInfo: "手机号不能为空"
},
{
limit: "phone",
param: "",
errInfo: "手机号格式错误"
}
],
'addOwnerInfo.idCard': [{
limit: "maxLength",
param: "64",
errInfo: "身份证格式不对"
},
{
limit: "idCard",
param: "",
errInfo: "身份证格式错误"
}
],
'addOwnerInfo.sex': [{
limit: "required",
param: "",
errInfo: "性别不能为空"
}],
'addOwnerInfo.remark': [{
limit: "maxLength",
param: "200",
errInfo: "备注长度不能超过200位"
}]
});
},
saveOwnerInfo: function () {
if (!$that.addOwnerValidate()) {
vc.toast(vc.validate.errInfo);
return;
}
$that.addOwnerInfo.communityId = vc.getCurrentCommunity().communityId;
vc.http.apiPost('/owner.saveOwner',
JSON.stringify($that.addOwnerInfo), {
emulateJSON: true
},
function (json, res) {
//vm.menus = vm.refreshMenuActive(JSON.parse(json),0);
let _json = JSON.parse(json);
if (_json.code == 0) {
//关闭model
$('#addOwnerModel').modal('hide');
$that.clearAddOwnerInfo();
vc.toast("添加成功");
vc.emit($props.notifyLoadDataComponentName, 'listOwnerData', {});
return;
} else {
vc.toast(_json.msg);
}
},
function (errInfo, error) {
console.log('请求失败处理');
vc.toast(errInfo);
});
},
clearAddOwnerInfo: function () {
let _componentTitle = $that.addOwnerInfo.componentTitle;
$that.addOwnerInfo = {
componentTitle: _componentTitle,
name: '',
age: '',
link: '',
address: '',
sex: '',
ownerTypeCd: '',
remark: '',
ownerId: '',
ownerPhoto: '',
ownerPhotoUrl: '',
idCard: '',
cardNumber: '',
videoPlaying: true,
mediaStreamTrack: null,
attrs: []
};
this._loadOwnerAttrSpec();
},
_addUserMedia: function () {
return navigator.getUserMedia = navigator.getUserMedia ||
navigator.webkitGetUserMedia ||
navigator.mozGetUserMedia ||
navigator.msGetUserMedia || null;
},
_initAddOwnerMedia: function () {
if ($that._addUserMedia()) {
let constraints = {
video: true,
audio: false
};
let video = document.getElementById('ownerPhoto');
let media = navigator.getUserMedia(constraints, function (stream) {
let url = window.URL || window.webkitURL;
$that.addOwnerInfo.mediaStreamTrack = typeof stream.stop === 'function' ? stream : stream.getTracks()[0];
try {
video.src = url ? url.createObjectURL(stream) : stream;
} catch (error) {
video.srcObject = stream;
}
video.play();
$that.addOwnerInfo.videoPlaying = true;
}, function (error) {
$that.addOwnerInfo.videoPlaying = false;
});
} else {
$that.addOwnerInfo.videoPlaying = false;
console.log("初始化视频失败");
}
},
_takePhoto: function () {
if ($that.addOwnerInfo.videoPlaying) {
let canvas = document.getElementById('canvas');
let video = document.getElementById('ownerPhoto');
let w = video.videoWidth;
// 默认按比例压缩
let h = video.videoHeight;
if (h > 1080 || w > 1080) {
let _rate = 0;
if (h > w) {
_rate = h / 1080;
h = 1080;
w = Math.floor(w / _rate);
} else {
_rate = w / 1080;
w = 1080;
h = Math.floor(h / _rate);
}
}
canvas.width = w;
canvas.height = h;
canvas.getContext('2d').drawImage(video, 0, 0, w, h);
var data = canvas.toDataURL('image/jpeg', 0.3);
// 改为异步上传图片
this._doUploadImageAddOwner(data);
// $that.addOwnerInfo.ownerPhoto = data;
//document.getElementById('photo').setAttribute('src', data);
//关闭拍照摄像头
$that._closeVedio();
} else {
vc.toast('未检测到摄像头');
}
},
_uploadPhoto: function (event) {
//$that.addOwnerInfo.ownerPhoto = "";
$("#uploadOwnerPhoto").trigger("click")
},
_choosePhoto: function (event) {
var photoFiles = event.target.files;
if (photoFiles && photoFiles.length > 0) {
// 获取目前上传的文件
var file = photoFiles[0]; // 文件大小校验的动作
if (file.size > 1024 * 1024 * 1) {
vc.toast("图片大小不能超过 1MB!")
return false;
}
// 改为异步上传图片
$that._doUploadImageAddOwner(file);
}
},
// 异步上传图片
_doUploadImageAddOwner: function (_file) {
var param = new FormData();
param.append("uploadFile", _file);
param.append('communityId', vc.getCurrentCommunity().communityId);
//发送get请求
vc.http.upload('/upload/uploadFile',
param, {
emulateJSON: true,
//添加请求头
headers: {
"Content-Type": "multipart/form-data"
}
},
function (json, res) {
console.log(res);
// if (res.status != 200) {
// vc.toast("上传文件失败");
// return;
// }
let _json = JSON.parse(json);
console.log(_json);
$that.addOwnerInfo.ownerPhoto = _json.data.fileId;
$that.addOwnerInfo.ownerPhotoUrl = _json.data.url;
console.log($that.addOwnerInfo.ownerPhotoUrl)
},
function (errInfo, error) {
console.log('请求失败处理');
vc.toast(errInfo);
}
);
},
_reOpenVedio: function () {
$that.addOwnerInfo.ownerPhoto = "";
$that.addOwnerInfo.ownerPhotoUrl = "";
$that._initAddOwnerMedia();
},
_closeVedio: function () {
if ($that.addOwnerInfo.mediaStreamTrack != null) {
$that.addOwnerInfo.mediaStreamTrack.stop();
}
},
_loadOwnerAttrSpec: function () {
$that.addOwnerInfo.attrs = [];
vc.getAttrSpec('building_owner_attr', function (data) {
data.forEach(item => {
item.value = '';
if (item.specShow == 'Y') {
item.values = [];
$that._loadAttrValue(item.specCd, item.values);
$that.addOwnerInfo.attrs.push(item);
}
});
});
},
_loadAttrValue: function (_specCd, _values) {
vc.getAttrValue(_specCd, function (data) {
data.forEach(item => {
if (item.valueShow == 'Y') {
_values.push(item);
}
});
});
},
_closeSaveOwnerModal: function () {
$that._closeVedio();
$('#addOwnerModel').modal('hide');
},
addOwnerIDCardChange: function () {
let idCard = $that.addOwnerInfo.idCard;
// 1 "验证通过!", 0 //校验不通过
var format = /^(([1][1-5])|([2][1-3])|([3][1-7])|([4][1-6])|([5][0-4])|([6][1-5])|([7][1])|([8][1-2]))\d{4}(([1][9]\d{2})|([2]\d{3}))(([0][1-9])|([1][0-2]))(([0][1-9])|([1-2][0-9])|([3][0-1]))\d{3}[0-9xX]$/;
//号码规则校验
if (!format.test(idCard)) {
vc.toast('身份证号码不合规');
$that.addOwnerInfo.idCard = "";
return;
}
//区位码校验
//出生年月日校验 前正则限制起始年份为1900;
var year = idCard.substr(6, 4), //身份证年
month = idCard.substr(10, 2), //身份证月
date = idCard.substr(12, 2), //身份证日
time = Date.parse(month + '-' + date + '-' + year), //身份证日期时间戳date
now_time = Date.parse(new Date()), //当前时间戳
dates = (new Date(year, month, 0)).getDate(); //身份证当月天数
if (time > now_time || date > dates) {
vc.toast("身份证号码不合规");
$that.addOwnerInfo.idCard = "";
return;
}
//校验码判断
var c = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); //系数
var b = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); //校验码对照表
var id_array = idCard.split("");
var sum = 0;
for (var k = 0; k < 17; k++) {
sum += parseInt(id_array[k]) * parseInt(c[k]);
}
if (id_array[17].toUpperCase() != b[sum % 11].toUpperCase()) {
vc.toast('身份证校验码不合规');
$that.addOwnerInfo.idCard = "";
return;
}
$that.addOwnerInfo.sex = vc.idCardInfoExt(idCard, 2) + "";
$that.addOwnerInfo.age = vc.idCardInfoExt(idCard, 3) + "";
},
}
});
})(window.vc);