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.
129 lines
2.6 KiB
129 lines
2.6 KiB
<template>
|
|
<view class="poster-poster" v-if="status === false">
|
|
<view class="tip">
|
|
<!-- #ifndef H5 -->
|
|
<text class="iconfont icon-shuoming"></text>提示:长按图片保存至手机相册
|
|
<!-- #endif -->
|
|
</view>
|
|
<view class="poster">
|
|
<!-- #ifndef APP-PLUS -->
|
|
<image :src="image" mode="widthFix" show-menu-by-longpress />
|
|
<!-- #endif -->
|
|
<!-- #ifdef APP-PLUS -->
|
|
<image :src="image" mode="widthFix" @longtap="longtap"/>
|
|
<!-- #endif -->
|
|
</view>
|
|
</view>
|
|
</template>
|
|
<script>
|
|
import {
|
|
getBargainPoster,
|
|
getCombinationPoster
|
|
} from "@/api/activity";
|
|
|
|
export default {
|
|
name: "Poster",
|
|
components: {},
|
|
props: {},
|
|
data () {
|
|
return {
|
|
status: true,
|
|
id: 0,
|
|
image: ""
|
|
};
|
|
},
|
|
mounted () {
|
|
var id = this.$yroute.query.id;
|
|
var type = this.$yroute.query.type;
|
|
this.id = id;
|
|
if (type == 2) {
|
|
this.getBargainPoster();
|
|
} else {
|
|
this.getCombinationPoster();
|
|
}
|
|
},
|
|
methods: {
|
|
// 砍价海报
|
|
getBargainPoster: function () {
|
|
var that = this;
|
|
let from = this.$deviceType
|
|
if (from == 'weixin' || this.$deviceType == 'weixinh5') {
|
|
from = 'uniappH5'
|
|
}
|
|
getBargainPoster({
|
|
bargainId: that.id,
|
|
from
|
|
})
|
|
.then(res => {
|
|
that.image = res.data.url;
|
|
that.status = false;
|
|
})
|
|
.catch(res => {
|
|
uni.showToast({
|
|
title: res.msg,
|
|
icon: "none",
|
|
duration: 2000
|
|
});
|
|
});
|
|
},
|
|
// 拼团海报
|
|
getCombinationPoster: function () {
|
|
var that = this;
|
|
console.log(this.$deviceType)
|
|
let from = this.$deviceType
|
|
if (from == 'weixin' || this.$deviceType == 'weixinh5') {
|
|
from = 'uniappH5'
|
|
}
|
|
console.log(from)
|
|
getCombinationPoster({
|
|
id: that.id,
|
|
from
|
|
})
|
|
.then(res => {
|
|
that.image = res.data.url;
|
|
that.status = false;
|
|
})
|
|
.catch(res => {
|
|
uni.showToast({
|
|
title: res.msg,
|
|
icon: "none",
|
|
duration: 2000
|
|
});
|
|
});
|
|
},
|
|
// app端长按保存
|
|
longtap () {
|
|
// 先下载图片
|
|
uni.downloadFile({
|
|
url: this.img,
|
|
success: (res) => {
|
|
// 获取到图片本地地址后再保存图片到相册(因为此方法不支持远程地址)
|
|
uni.saveImageToPhotosAlbum({
|
|
filePath: res.tempFilePath,
|
|
success: () => {
|
|
uni.showToast({
|
|
title: "保存成功!",
|
|
});
|
|
},
|
|
fail: () => {
|
|
uni.showToast({
|
|
title: "保存失败",
|
|
});
|
|
},
|
|
});
|
|
},
|
|
});
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style scoped lang="less">
|
|
page {
|
|
background-color: #eb3729;
|
|
}
|
|
|
|
.poster-poster {
|
|
height: unset !important;
|
|
}
|
|
</style>
|