|
|
@@ -2,162 +2,170 @@
|
|
|
<div>
|
|
|
<div class="cameraDiv1">
|
|
|
<div class="imgPre">
|
|
|
- <van-icon class="photobrowsing" name="expand-o" size="22px" color="#969696" v-if="imgArr!=''" @click="deleteImgs(imgArr)"/>
|
|
|
- <img :src="imgArr" alt="" v-if="imgArr!=''">
|
|
|
+ <van-icon
|
|
|
+ class="photobrowsing"
|
|
|
+ name="expand-o"
|
|
|
+ size="22px"
|
|
|
+ color="#1989fa"
|
|
|
+ v-if="imgArr != ''"
|
|
|
+ @click="deleteImgs(imgArr)" />
|
|
|
+ <img :src="imgArr" alt="" v-if="imgArr != ''" />
|
|
|
</div>
|
|
|
<p class="coverImg" @click="uploadImg">
|
|
|
- <van-icon class="photo ico" name="photograph" size="16px" color="#969696">{{ imgText }}</van-icon>
|
|
|
+ <van-icon class="photo ico" name="photograph" size="16px" color="#969696">{{
|
|
|
+ imgText
|
|
|
+ }}</van-icon>
|
|
|
</p>
|
|
|
</div>
|
|
|
- <p style="text-align: center;">{{ imgText }}</p>
|
|
|
+ <p style="text-align: center">{{ imgText }}</p>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
-import {ImagePreview} from "vant";
|
|
|
+import { ImagePreview } from 'vant';
|
|
|
import axios from 'axios';
|
|
|
-import {uploadImageaddress} from "@/api/index";
|
|
|
+import { uploadImageaddress } from '@/api/index';
|
|
|
|
|
|
export default {
|
|
|
name: 'uploadImg',
|
|
|
props: {
|
|
|
uploadid: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
imgText: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
visitsId: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
taskId: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
collectionId: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
type: {
|
|
|
type: Number,
|
|
|
- default: 1
|
|
|
+ default: 1,
|
|
|
},
|
|
|
imgArr: {
|
|
|
type: String,
|
|
|
- default: ''
|
|
|
+ default: '',
|
|
|
},
|
|
|
},
|
|
|
data() {
|
|
|
return {
|
|
|
shows: false,
|
|
|
- url: ""
|
|
|
- }
|
|
|
+ url: '',
|
|
|
+ };
|
|
|
},
|
|
|
methods: {
|
|
|
deleteImgs(val) {
|
|
|
ImagePreview([val]);
|
|
|
},
|
|
|
- uploadImg(){
|
|
|
+ uploadImg() {
|
|
|
if (localStorage.getItem('chainName') == null) {
|
|
|
- this.$toast("请输入名称!")
|
|
|
- return
|
|
|
+ this.$toast('请输入名称!');
|
|
|
+ return;
|
|
|
}
|
|
|
let url = window.location.href;
|
|
|
let that = this;
|
|
|
- let wx = this.wx
|
|
|
- let qiyeData
|
|
|
+ let wx = this.wx;
|
|
|
+ let qiyeData;
|
|
|
const instance = axios.create();
|
|
|
|
|
|
- instance.defaults.headers.common['userId'] = localStorage.getItem("loginName");
|
|
|
- instance.get(process.env.VUE_APP_BASE_API + 'mobile/wx/ticket',
|
|
|
- {
|
|
|
- params: {
|
|
|
- url: url
|
|
|
- }
|
|
|
- }).then(response => {
|
|
|
- if (response.status == 200) {
|
|
|
- qiyeData = response.data.data;
|
|
|
- wx.config({
|
|
|
- beta: true, // 必须这么写,否则wx.invoke调用形式的jsapi会有问题
|
|
|
- debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
|
|
|
- appId: qiyeData.appId, // 必填,企业微信的corpID
|
|
|
- timestamp: qiyeData.timestamp, // 必填,生成签名的时间戳
|
|
|
- nonceStr: qiyeData.nonceStr, // 必填,生成签名的随机串
|
|
|
- signature: qiyeData.signature, // 必填,签名,见 附录-JS-SDK使用权限签名算法
|
|
|
- jsApiList: ["ready", "chooseImage","uploadImage","getLocation"] // 必填,需要使用的JS接口列表,凡是要调用的接口都需要传进来
|
|
|
- });
|
|
|
- wx.ready(function () {
|
|
|
- var locations=""
|
|
|
- wx.getLocation({
|
|
|
- type: 'gcj02',
|
|
|
- success: function (response) {
|
|
|
- locations=response
|
|
|
+ instance.defaults.headers.common['userId'] = localStorage.getItem('loginName');
|
|
|
+ instance
|
|
|
+ .get(process.env.VUE_APP_BASE_API + 'mobile/wx/ticket', {
|
|
|
+ params: {
|
|
|
+ url: url,
|
|
|
+ },
|
|
|
+ })
|
|
|
+ .then((response) => {
|
|
|
+ if (response.status == 200) {
|
|
|
+ qiyeData = response.data.data;
|
|
|
+ wx.config({
|
|
|
+ beta: true, // 必须这么写,否则wx.invoke调用形式的jsapi会有问题
|
|
|
+ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
|
|
|
+ appId: qiyeData.appId, // 必填,企业微信的corpID
|
|
|
+ timestamp: qiyeData.timestamp, // 必填,生成签名的时间戳
|
|
|
+ nonceStr: qiyeData.nonceStr, // 必填,生成签名的随机串
|
|
|
+ signature: qiyeData.signature, // 必填,签名,见 附录-JS-SDK使用权限签名算法
|
|
|
+ jsApiList: ['ready', 'chooseImage', 'uploadImage', 'getLocation'], // 必填,需要使用的JS接口列表,凡是要调用的接口都需要传进来
|
|
|
+ });
|
|
|
+ wx.ready(function () {
|
|
|
+ var locations = '';
|
|
|
+ wx.getLocation({
|
|
|
+ type: 'gcj02',
|
|
|
+ success: function (response) {
|
|
|
+ locations = response;
|
|
|
|
|
|
- wx.chooseImage({
|
|
|
- count: 1,
|
|
|
- sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
|
|
|
- sourceType: ['camera'], // 可以指定来源是相册还是相机,默认二者都有
|
|
|
- defaultCameraMode: "normal", //表示进入拍照界面的默认模式,目前有normal与batch两种选择,normal表示普通单拍模式,batch表示连拍模式,不传该参数则为normal模式。从3.0.26版本开始支持front和batch_front两种值,其中front表示默认为前置摄像头单拍模式,batch_front表示默认为前置摄像头连拍模式。(注:用户进入拍照界面仍然可自由切换两种模式)
|
|
|
- isSaveToAlbum:0,
|
|
|
- success: function (res) {
|
|
|
- var localIds=""
|
|
|
- if(res.localIds!=undefined){
|
|
|
- localIds= res.localIds[0]
|
|
|
- }else{
|
|
|
- localIds=res.localId
|
|
|
- }
|
|
|
- wx.uploadImage({
|
|
|
- localId: localIds,
|
|
|
- isShowProgressTips: 1,
|
|
|
- success: function (res) {
|
|
|
- that.uploadImagev(res.serverId,locations.latitude, locations.longitude)
|
|
|
+ wx.chooseImage({
|
|
|
+ count: 1,
|
|
|
+ sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
|
|
|
+ sourceType: ['camera'], // 可以指定来源是相册还是相机,默认二者都有
|
|
|
+ defaultCameraMode: 'normal', //表示进入拍照界面的默认模式,目前有normal与batch两种选择,normal表示普通单拍模式,batch表示连拍模式,不传该参数则为normal模式。从3.0.26版本开始支持front和batch_front两种值,其中front表示默认为前置摄像头单拍模式,batch_front表示默认为前置摄像头连拍模式。(注:用户进入拍照界面仍然可自由切换两种模式)
|
|
|
+ isSaveToAlbum: 0,
|
|
|
+ success: function (res) {
|
|
|
+ var localIds = '';
|
|
|
+ if (res.localIds != undefined) {
|
|
|
+ localIds = res.localIds[0];
|
|
|
+ } else {
|
|
|
+ localIds = res.localId;
|
|
|
}
|
|
|
- });
|
|
|
- }
|
|
|
- });
|
|
|
- },
|
|
|
- fail: function () {
|
|
|
- that.$dialog.alert({
|
|
|
- message: 'GPS未开启',
|
|
|
- })
|
|
|
- }
|
|
|
+ wx.uploadImage({
|
|
|
+ localId: localIds,
|
|
|
+ isShowProgressTips: 1,
|
|
|
+ success: function (res) {
|
|
|
+ that.uploadImagev(res.serverId, locations.latitude, locations.longitude);
|
|
|
+ },
|
|
|
+ });
|
|
|
+ },
|
|
|
+ });
|
|
|
+ },
|
|
|
+ fail: function () {
|
|
|
+ that.$dialog.alert({
|
|
|
+ message: 'GPS未开启',
|
|
|
+ });
|
|
|
+ },
|
|
|
+ });
|
|
|
});
|
|
|
-
|
|
|
- })
|
|
|
- }
|
|
|
- });
|
|
|
+ }
|
|
|
+ });
|
|
|
},
|
|
|
- uploadImagev(meidaId,lat,lng){
|
|
|
+ uploadImagev(meidaId, lat, lng) {
|
|
|
var that = this;
|
|
|
- var form={
|
|
|
- mediaId:meidaId,
|
|
|
- storeName:localStorage.getItem('chainName'),
|
|
|
- locationRemark:localStorage.getItem('locationRemark'),
|
|
|
- deptName:localStorage.getItem('deptName'),
|
|
|
- lat:lat,
|
|
|
- lng:lng
|
|
|
- }
|
|
|
+ var form = {
|
|
|
+ mediaId: meidaId,
|
|
|
+ storeName: localStorage.getItem('chainName'),
|
|
|
+ locationRemark: localStorage.getItem('locationRemark'),
|
|
|
+ deptName: localStorage.getItem('deptName'),
|
|
|
+ lat: lat,
|
|
|
+ lng: lng,
|
|
|
+ };
|
|
|
var loind1 = that.$toast.loading({
|
|
|
duration: 0,
|
|
|
message: '上传中...',
|
|
|
forbidClick: true,
|
|
|
});
|
|
|
- uploadImageaddress(form).then(res=>{
|
|
|
+ uploadImageaddress(form).then((res) => {
|
|
|
if (res.code == 200) {
|
|
|
- that.imgArr = res.data.url
|
|
|
+ that.imgArr = res.data.url;
|
|
|
loind1.clear();
|
|
|
- that.$toast("上传成功!")
|
|
|
- that.$emit('newimgarr', {fileUrl: res.data.url, type: that.type});
|
|
|
+ that.$toast('上传成功!');
|
|
|
+ that.$emit('newimgarr', { fileUrl: res.data.url, type: that.type });
|
|
|
} else {
|
|
|
- that.$toast("上传失败!")
|
|
|
+ that.$toast('上传失败!');
|
|
|
}
|
|
|
- })
|
|
|
- }
|
|
|
+ });
|
|
|
+ },
|
|
|
},
|
|
|
-}
|
|
|
+};
|
|
|
</script>
|
|
|
|
|
|
<style scoped>
|
|
|
@@ -197,7 +205,7 @@ export default {
|
|
|
z-index: 99;
|
|
|
background-color: rgba(255, 255, 255, 0.8);
|
|
|
border-bottom-left-radius: 3px;
|
|
|
- border-top-left-radius: 3px
|
|
|
+ border-top-left-radius: 3px;
|
|
|
}
|
|
|
|
|
|
.coverImg {
|