日照项目的居民端小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

427 lines
11 KiB

import { config } from "../../../../config/config";
var QQMapWX = require("../../utils/qqmap-wx-jssdk.js");
const api = require("../../../../utils/api");
import { wxRequestPost } from "@utils/promise-wx-api";
import { nextTick } from "@utils/tools";
const app = getApp();
Page({
/**
* 页面的初始数据
*/
data: {
addlive: false,
dataUploading: false,
BASEURL: config.apiUrl,
qqmapsdk: "",
signin: {}, //活动打卡地点详情
actId: "", //活动ID
operationDesc: "", //打卡描述
operationDesc_: "",
locationLongitude: Number, //打卡位置经度
locationLatitude: Number, // 打卡位置纬度
operationAddress: "", //打卡地址
images: [], //图片
clockType: Number, //打卡类型(0-打卡,1-更新打卡)
effectiveFlag: Number, //打卡是否有效(0-否,1-是)
phraseList: [], //常用于列表
phraseId: "", //常用语id
ldata: false,
inRange: false,
live: true,
act: "", //签到打卡,添加实况
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
var that = this;
const qqmapsdk = new QQMapWX({
key: "CMJBZ-4DECI-JXGGN-5B4WU-QLV2H-B5BEJ",
});
if (options.currentUserStatus == "4") {
//0-打卡
that.setData({
clockType: 0,
});
} else {
//更新打卡
that.setData({
clockType: 1,
});
}
that.setData({
qqmapsdk,
act: options.act,
id: options.id,
effectiveFlag: 1,
});
if (options.act == "sign") {
wx.setNavigationBarTitle({
title: "签到打卡",
});
} else {
wx.setNavigationBarTitle({
title: "添加实况",
});
}
//that.getPhraseList(); //常用语列表
//that.clockAddressDetail();
that.getPosition();
},
/**
* 生命周期函数--监听页面显示
*/
onShow: function () {
// this.getPosition()
},
checkboxChange: function (e) {
console.log(
"checkbox发生change事件,携带value值为:",
e.detail.value.length
);
if (e.detail.value.length == 0) {
this.setData({
live: false,
});
} else {
this.setData({
live: true,
});
}
},
// 判断当前地址是否在签到范围内
async isInRange(lat: Number, lng: Number) {
let fmData = {
longitude: lng,
latitude: lat,
actId: this.data.id,
};
let rst = await wxRequestPost("heart/resi/act/checksigninaddress", fmData, {
isMock: false,
});
console.log("checksigninaddress", rst.data.data.data);
console.log("rst.msg", rst.msg);
if (rst.msg == "success") {
console.log("rst.data.isAddress", rst.data.data.data.isAddress);
this.setData({
inRange: rst.data.data.data.isAddress,
});
if (!rst.data.data.data.isAddress) {
wx.showToast({
title: "尚未进入签到范围",
icon: "none",
duration: 3000,
});
}
}
},
//获取经纬度
getPosition() {
var that = this;
// wx.showLoading({
// title: "正在获取位置",
// })
wx.getLocation({
type: "gcj02",
success: (res) => {
that.reverseGeocoder(res);
that.setData({
ldata: false,
locationLongitude: res.longitude,
locationLatitude: res.latitude,
});
if (this.data.act == "sign") {
this.isInRange(res.latitude, res.longitude);
}
},
fail: (res) => {
//wx.hideLoading();
if (res.errMsg === "getLocation:fail auth deny") {
that.setData({
ldata: true,
});
wx.showToast({
title: "位置获取失败,请开启手机GPS定位或重新授权获取位置信息",
icon: "none",
duration: 3000,
});
console.log(res);
}
},
});
},
handler: function (e) {
var that = this;
if (!e.detail.authSetting["scope.userLocation"]) {
that.setData({
ldata: true,
});
} else {
that.setData({
ldata: false,
});
wx.getLocation({
type: "gcj02",
success: function (res) {
var latitude = res.latitude;
var longitude = res.longitude;
that.setData({
locationLongitude: longitude,
locationLatitude: latitude,
});
},
});
}
},
// 逆地址解析
reverseGeocoder({ latitude, longitude }) {
var that = this;
that.data.qqmapsdk.reverseGeocoder({
location: {
latitude,
longitude,
},
success: (res) => {
//wx.hideLoading();
if (res.message === "query ok") {
that.setData({
operationAddress: res.result.address,
});
}
},
});
},
getPhraseList() {
let that = this;
api.getPhraseList().then(function (res) {
//常用语列表
// console.log('常用语列表:' + JSON.stringify(res.data))
that.setData({
phraseList: res.data,
});
});
},
toOperationDesc(phrase) {
//常用于点击事件
// console.log(phrase.currentTarget.dataset.phrase)
this.setData({
operationDesc:
this.data.operationDesc + phrase.currentTarget.dataset.phrase,
phraseId: phrase.currentTarget.dataset.id,
});
// console.log(phrase.currentTarget.dataset.phrase)
},
// 上传图片
onChange(e) {
// console.log('onChange', e)
const { file } = e.detail;
if (file.status === "uploading") {
this.setData({
progress: 0,
});
wx.showLoading();
} else if (file.status === "done") {
this.setData({
imageUrl: file.url,
});
}
console.log(e);
let images = [];
e.detail.fileList.forEach((item, index) => {
if (item.res !== undefined) {
const imageUrl = JSON.parse(e.detail.fileList[index].res.data).data.url;
images.push(imageUrl);
}
});
this.setData({
images: images,
});
},
// 上传完成
onComplete() {
wx.hideLoading();
},
// 点击图片放大
onPreview(e) {
const { file, fileList } = e.detail;
wx.previewImage({
current: file.url,
urls: fileList.map((n) => n.url),
});
},
// 填写意见
// bindInput: function (e) {
// this.setData({
// operationDesc: e.detail.value + this.data.operationDesc,
// operationDesc_: e.detail.value
// })
// if (this.data.operationDesc_.length == 0){
// this.setData({
// operationDesc: e.detail.value,
// operationDesc_: e.detail.value
// })
// }
// console.log(this.data.operationDesc_)
// },
getbindinput(e) {
this.setData({
operationDesc: e.detail.value,
});
},
/**
* 数据提交方法
*/
submission() {
if (this.data.live) {
if (this.data.operationDesc === "" && this.data.images.length == 0) {
wx.showToast({
title: "请填写打卡描述或上传实况图片",
icon: "none",
duration: 3000,
});
return false;
}
}
if (this.data.dataUploading) {
wx.showToast({
title: "正在提交",
icon: "none",
duration: 3000,
});
return false;
}
this.setData({
dataUploading: true,
});
const signinLongitude = this.data.signin.signinLongitude; //经度
const signinLatitude = this.data.signin.signinLatitude; //纬度
var clockLongitudeMy = 0;
var clockLatitudeMy = 0;
const params = {
actId: this.data.id,
desc: this.data.operationDesc,
longitude: this.data.locationLongitude, //clockLongitudeMy, //打卡位置经度
latitude: this.data.locationLatitude, //clockLatitudeMy, //打卡位置纬度
address: this.data.operationAddress,
images: this.data.images,
syncLive: this.data.live ? 1 : 0, //打卡类型(0-打卡,1-更新打卡)
customerId: app.globalData.customerId, //打卡是否有效(0-否,1-是)
};
let that = this;
api
.clock(params)
.then(function (res) {
that.setData({
dataUploading: false,
});
if (res.code == 0) {
wx.showToast({
title: "签到打卡成功",
icon: "none",
duration: 3000,
complete: function () {
setTimeout(function () {
wx.navigateBack({
delta: 1,
});
}, 1000);
},
});
}
})
.catch((err) => {
that.setData({
dataUploading: false,
});
});
},
newlive() {
if (this.data.live) {
if (this.data.operationDesc === "" && this.data.images.length == 0) {
wx.showToast({
title: "请填写打卡描述或上传实况图片",
icon: "none",
duration: 3000,
});
return false;
}
}
if (this.data.addlive) {
wx.showToast({
title: "正在提交",
icon: "none",
duration: 3000,
});
return false;
}
this.setData({
addlive: true,
});
const params = {
actId: this.data.id,
desc: this.data.operationDesc,
longitude: this.data.locationLongitude, //clockLongitudeMy, //打卡位置经度
latitude: this.data.locationLatitude, //clockLatitudeMy, //打卡位置纬度
address: this.data.operationAddress,
images: this.data.images,
customerId: app.globalData.customerId, //打卡是否有效(0-否,1-是)
};
let that = this;
api.newlive(params).then(function (res) {
if (res.code == 0) {
that.setData({
operationDesc: "",
images: [],
fileList: [],
});
wx.showToast({
title: "添加实况成功",
icon: "none",
mask: true,
duration: 3000,
complete: async function () {
await nextTick(1500);
const pages = getCurrentPages();
const prevPage = pages[pages.length - 2]; // 上一页
//返回上一页并显示实况页面
prevPage.setData({
curtab: "live",
});
wx.navigateBack({
delta: 1,
});
that.setData({
addlive: false,
});
},
});
} else {
that.setData({
addlive: false,
});
}
});
},
Rad(d) {
//经纬度转换成三角函数中度分表形式。
return (d * Math.PI) / 180.0;
},
clockAddressDetail() {
//活动打卡地点详情
let that = this;
const id = that.data.id;
api.clockAddressDetail(id).then(function (res) {
if (res.code == 0) {
that.setData({
signin: res.data,
});
}
});
},
});